

# Stereo Low-Power CODEC with Video Buffer

### DESCRIPTION

The WM8946 is a highly integrated low power hi-fi CODEC designed for portable devices such as digital still cameras.

Up to 6 analogue inputs may be connected; a 2-channel digital microphone interface is also provided. Flexible output mixing options support single-ended and differential configurations, with outputs derived from the digital audio paths or from analogue bypass paths. Twin stereo outputs or stereo line and mono BTL headphone/speaker drive may be supported.

Flexible digital mixing and powerful DSP functions are available. Programmable filters and other processes may be applied to the ADC or DAC signal paths. The DSP functions include 3D-stereo enhancement, 5 notch filters, 5-band EQ, dynamic range control and the Wolfson ReTune™ feature.

The ReTune™ feature is a sophisticated digital filter that can compensate for imperfect characteristics of the housing, loudspeaker or microphone components in an application. The ReTune™ algorithm can provide acoustic equalisation and selective phase (delay) control of specific frequency bands.

The WM8946 is controlled via a I2C or SPI interface. Additional functions include Digital beep generator, Video buffer, programmable GPIO functions, Frequency Locked Loop (FLL) for flexible clocking support and integrated LDO for low noise supply regulation.

The WM8946 is supplied in 36-ball W-CSP package, ideal for portable systems.

### **FEATURES**

- Hi-fi audio CODEC
  - 94dB SNR during ADC recording ('A' weighted)
  - 96dB SNR during DAC playback ('A' weighted)
- 6 analogue audio inputs
- Integrated bias reference for electret microphones
- 2-channel digital microphone interface
- Powerful digital mixing / DSP functions:
  - 3D-stereo enhancement
  - 5-notch filters
  - 5-band equalizer (EQ)
  - ReTune™ parametric filter
  - Dynamic range control and noise gate
  - Low-pass/High-pass filters
  - Direct Form 1 (DF1) programmable digital filter
- Digital beep generator
- 4 analogue audio outputs
- Stereo line output
- · Mono BTL headphone/speaker output driver
- I2S digital audio interface sample rates 8kHz to 48kHz
- Frequency Locked Loop (FLL) frequency conversion / filter
- Video buffer function
- Integrated LDO low-noise voltage regulator
- 36-ball W-CSP package (2.97 x 3.07 x 0.7mm, 0.5mm pitch)

### **APPLICATIONS**

- Digital Still Cameras (DSC)
- Multimedia phones



# **TABLE OF CONTENTS**

| DESCRIPTION                            |      |
|----------------------------------------|------|
| FEATURES                               | 1    |
| APPLICATIONS                           |      |
| TABLE OF CONTENTS                      | 2    |
| BLOCK DIAGRAM                          |      |
| PIN CONFIGURATION                      |      |
| ORDERING INFORMATION                   |      |
|                                        |      |
| PIN DESCRIPTION                        |      |
| ABSOLUTE MAXIMUM RATINGS               |      |
| RECOMMENDED OPERATING CONDITIONS       | _    |
| THERMAL PERFORMANCE                    |      |
| ELECTRICAL CHARACTERISTICS             | 10   |
| TERMINOLOGY                            | . 13 |
| TYPICAL PERFORMANCE                    | 14   |
| POWER CONSUMPTION                      |      |
| AUDIO SIGNAL PATHS DIAGRAM             | _    |
| SIGNAL TIMING REQUIREMENTS             |      |
| SYSTEM CLOCK TIMING                    |      |
| AUDIO INTERFACE TIMING                 |      |
| MASTER MODE                            |      |
| SLAVE MODE                             |      |
| CONTROL INTERFACE TIMING               |      |
| DEVICE DESCRIPTION                     |      |
| INTRODUCTION                           |      |
| ANALOGUE INPUT SIGNAL PATH             |      |
| INPUT PGA ENABLE                       |      |
| INPUT PGA CONFIGURATION                |      |
| MICROPHONE BIAS CONTROL                |      |
| INPUT PGA GAIN CONTROL                 |      |
| DIGITAL MICROPHONE INTERFACE           |      |
| ANALOGUE-TO-DIGITAL CONVERTER (ADC)    |      |
| ADC VOLUME CONTROL                     | 30   |
| ADC HIGH PASS FILTER                   | 32   |
| DSP CORE                               | . 33 |
| DSP CONFIGURATION MODES                | 33   |
| LOW-PASS / HIGH-PASS FILTER (LPF/HPF)  | 34   |
| 3D SURROUND                            |      |
| 5-NOTCH FILTER                         |      |
| DF1 FILTER                             |      |
| RETUNE <sup>™</sup> FILTER             |      |
| 5-BAND EQ                              |      |
| DYNAMIC RANGE CONTROL (DRC)            |      |
| SIGNAL ENHANCEMENT REGISTER CONTROLS   |      |
| DYNAMIC RANGE CONTROL (DRC)            |      |
| DRC COMPRESSION / EXPANSION / LIMITING |      |
| GAIN LIMITSGAIN READBACK               |      |
| DYNAMIC CHARACTERISTICS                |      |
| ANTI-CLIP CONTROL                      |      |
| QUICK-RELEASE CONTROL                  |      |
| DRC INITIAL VALUE                      |      |
| -                                      |      |



| DIGITAL-TO-ANALOGUE CONVERTER (DAC)              | 47  |
|--------------------------------------------------|-----|
| DAC DIGITAL VOLUME CONTROL                       |     |
| DAC AUTO-MUTE                                    |     |
| DAC SLOPING STOPBAND FILTER                      |     |
| DIGITAL BEEP GENERATOR                           |     |
| OUTPUT SIGNAL PATH                               |     |
| OUTPUT SIGNAL PATHS ENABLE                       | 53  |
| LINE OUTPUT MIXER CONTROL                        | 54  |
| SPEAKER PGA MIXER CONTROL                        | 56  |
| SPEAKER PGA VOLUME CONTROL                       | 59  |
| SPEAKER OUTPUT CONTROL                           |     |
| ANALOGUE OUTPUTS                                 | 62  |
| LINE OUTPUTS                                     |     |
| SPEAKER OUTPUTS                                  |     |
| EXTERNAL COMPONENTS FOR LINE OUTPUT              |     |
| LDO REGULATOR                                    |     |
| REFERENCE VOLTAGES AND MASTER BIAS               |     |
| POP SUPPRESSION CONTROL                          |     |
| DISABLED OUTPUT CONTROL                          |     |
| OUTPUT DISCHARGE CONTROL                         |     |
| DIGITAL AUDIO INTERFACE                          |     |
| MASTER AND SLAVE MODE OPERATION                  |     |
| AUDIO DATA FORMATS                               |     |
| COMPANDING                                       |     |
| LOOPBACK                                         |     |
| DIGITAL PULL-UP AND PULL-DOWN                    |     |
| CLOCKING AND SAMPLE RATES                        |     |
| DIGITAL MIC CLOCKING                             |     |
| FREQUENCY LOCKED LOOP (FLL)                      |     |
| EXAMPLE FLL CALCULATION                          |     |
| EXAMPLE FLL SETTINGS                             |     |
| VIDEO BUFFER                                     |     |
| RECOMMENDED VIDEO BUFFER INITIALISATION SEQUENCE |     |
| GENERAL PURPOSE INPUT/OUTPUT                     |     |
| GPIO FUNCTION SELECT                             |     |
| INTERRUPTS                                       |     |
| CONTROL INTERFACE                                |     |
| SELECTION OF CONTROL INTERFACE MODE              |     |
| 2-WIRE (I2C) CONTROL MODE                        |     |
| 3-WIRE (SPI) CONTROL MODE                        |     |
| 4-WIRE (SPI) CONTROL MODE                        | 100 |



| ١ | ۸ | 1 | ٨ | Λ | ጸ | q | 4 | 6 |
|---|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |   |

| POWER MANAGEMENT                                                 | 101 |
|------------------------------------------------------------------|-----|
| THERMAL SHUTDOWN                                                 | 103 |
| POWER ON RESET                                                   |     |
| SOFTWARE RESET AND DEVICE ID                                     | 105 |
| RECOMMENDED POWER UP / POWER-DOWN SEQUENCES                      | 106 |
| REGISTER MAP                                                     | 108 |
| REGISTER BITS BY ADDRESS                                         | 113 |
| DIGITAL FILTER CHARACTERISTICS                                   | 163 |
| ADC FILTER RESPONSE                                              |     |
| ADC HIGHPASS FILTER RESPONSE                                     |     |
| DAC FILTER RESPONSE                                              |     |
| APPLICATIONS INFORMATION                                         | 168 |
| RECOMMENDED EXTERNAL COMPONENTS                                  | 168 |
| AUDIO INPUT PATHS                                                | 168 |
| HEADPHONE / LINE OUTPUT PATHS                                    |     |
| BTL SPEAKER OUTPUT CONNECTION                                    |     |
| POWER SUPPLY DECOUPLING                                          |     |
| MICROPHONE BIAS CIRCUIT                                          |     |
| VIDEO BUFFER COMPONENTS                                          |     |
| RECOMMENDED EXTERNAL COMPONENTS DIAGRAMPCB LAYOUT CONSIDERATIONS |     |
| PACKAGE DIMENSIONS                                               |     |
|                                                                  | _   |
| IMPORTANT NOTICE                                                 |     |
| ADDRESS:                                                         |     |
|                                                                  |     |



## **BLOCK DIAGRAM**



## **PIN CONFIGURATION**

The WM8946 is supplied in a 36-pin CSP format. The pin configuration is illustrated below, showing the top-down view from above the chip.



## **ORDERING INFORMATION**

| ORDER CODE  | TEMPERATURE RANGE | PACKAGE                                   | MOISTURE<br>SENSITIVITY LEVEL | PEAK SOLDERING<br>TEMPERATURE |
|-------------|-------------------|-------------------------------------------|-------------------------------|-------------------------------|
| WM8946ECS/R | -40°C to +85°C    | 36-ball W-CSP<br>(Pb-free, tape and reel) | MSL1                          | 260°C                         |

Note:

Reel quantity = 5000

# **PIN DESCRIPTION**

| PIN NO | NAME          | TYPE                           | DESCRIPTION                                        |
|--------|---------------|--------------------------------|----------------------------------------------------|
| A1     | SPKVDD        | Supply                         | Supply for speaker driver                          |
| A2     | LDOVOUT       | Supply                         | LDO output                                         |
| A3     | LDOVDD        | Supply                         | LDO supply input                                   |
| A4     | VMIDC         | Analogue Output                | Midrail voltage decoupling capacitor               |
| A5     | DNC           | N/A                            | Do Not Connect                                     |
| A6     | DNC           | N/A                            | Do Not Connect                                     |
| B1     | SPKOUTR       | Analogue Output                | Right speaker mixer output                         |
| B2     | SPKOUTL       | Analogue Output                | Left speaker mixer output                          |
| В3     | GND           | Supply                         | Ground                                             |
| B4     | DNC           | N/A                            | Do Not Connect                                     |
| B5     | DNC           | N/A                            | Do Not Connect                                     |
| B6     | AUX1          | Analogue Input                 | Aux audio input                                    |
| C1     | LINEOUTL      | Analogue Output                | Left line mixer output                             |
| C2     | LINEOUTR      | Analogue Output                | Right line mixer output                            |
| C3     | ADCDAT        | Digital Output                 | ADC / Digital Microphone digital audio data        |
| C4     | MICBIAS       | Analogue Output                | Microphone bias                                    |
| C5     | AUX2          | Analogue Input                 | Aux audio input                                    |
| C6     | IN2L          | Analogue Input                 | Left input 2                                       |
| D1     | VBREFR        | Analogue Output                | Video buffer current reference resistor connection |
| D2     | VBOUT         | Analogue Output                | Video buffer output                                |
| D3     | CS/GPIO2      | Digital Input / Output         | Chip Select / GPIO2                                |
| D4     | IN1L/DMICDAT  | Analogue Input / Digital Input | Left input 1 / Digital Microphone data input       |
| D5     | IN1R          | Analogue Input                 | Right input 1                                      |
| D6     | IN2R          | Analogue Input                 | Right input 2                                      |
| E1     | VBIN          | Analogue Input                 | Video buffer input                                 |
| E2     | BCLK          | Digital Input / Output         | Audio interface bit clock                          |
| E3     | LRCLK         | Digital Input / Output         | Audio interface left / right clock                 |
| E4     | SDOUT/GPIO4   | Digital Input / Output         | Control interface data output / GPIO4              |
| E5     | DCVDD         | Supply                         | Digital core supply                                |
| E6     | SDA           | Digital Input / Output         | Control interface data input / output              |
| F1     | MCLK          | Digital Input                  | Master clock                                       |
| F2     | DACDAT        | Digital Input                  | DAC digital audio data                             |
| F3     | GPIO1         | Digital Input / Output         | GPIO1                                              |
| F4     | CIFMODE/GPIO3 | Digital Input / Output         | Control interface mode select / GPIO3              |
| F5     | DBVDD         | Supply                         | Digital buffer (I/O) supply                        |
| F6     | SCLK          | Digital Input                  | Control interface clock input                      |



WM8946 Production Data

## **ABSOLUTE MAXIMUM RATINGS**

Absolute Maximum Ratings are stress ratings only. Permanent damage to the device may be caused by continuously operating at or beyond these limits. Device functional operating limits and guaranteed performance specifications are given under Electrical Characteristics at the test conditions specified.



ESD Sensitive Device. This device is manufactured on a CMOS process. It is therefore generically susceptible to damage from excessive static voltages. Proper ESD precautions must be taken during handling and storage of this device.

Wolfson tests its package types according to IPC/JEDEC J-STD-020B for Moisture Sensitivity to determine acceptable storage conditions prior to surface mount assembly. These levels are:

MSL1 = unlimited floor life at <30°C / 85% Relative Humidity. Not normally stored in moisture barrier bag.

MSL2 = out of bag storage for 1 year at <30°C / 60% Relative Humidity. Supplied in moisture barrier bag.

MSL3 = out of bag storage for 168 hours at <30°C / 60% Relative Humidity. Supplied in moisture barrier bag.

The Moisture Sensitivity Level for each package type is specified in Ordering Information.

| CONDITION                                   | MIN   | MAX          |
|---------------------------------------------|-------|--------------|
| Supply voltages (DCVDD)                     | -0.3V | 2.5V         |
| Supply voltages (LDOVDD, DBVDD, SPKVDD)     | -0.3V | 4.5V         |
| Voltage range digital inputs                | -0.7V | DBVDD +0.7V  |
| Voltage range analogue inputs               | -0.7V | LDOVDD +0.7V |
| Operating temperature range, T <sub>A</sub> | -40°C | +85°C        |
| Junction temperature, T <sub>JMAX</sub>     | -40°C | +150°C       |
| Storage temperature after soldering         | -65°C | +150°C       |

## RECOMMENDED OPERATING CONDITIONS

| PARAMETER                   | SYMBOL | MIN  | TYP | MAX  | UNIT |
|-----------------------------|--------|------|-----|------|------|
| Digital supply range (Core) | DCVDD  | 1.62 | 1.8 | 1.98 | V    |
| Digital supply range (I/O)  | DBVDD  | 1.71 | 3.3 | 3.6  | V    |
| Analogue supply             | LDOVDD | 2.4  | 3.3 | 3.6  | V    |
| Speaker supply range        | SPKVDD | 1.71 | 3.3 | 3.6  | V    |
| Ground                      | GND    |      | 0   |      | V    |

#### Note:

To ensure pop-free device start-up, LDOVDD must be enabled before SPKVDD



## THERMAL PERFORMANCE

Thermal analysis should be performed in the intended application to prevent the WM8946 from exceeding maximum junction temperature. Several contributing factors affect thermal performance most notably the physical properties of the mechanical enclosure, location of the device on the PCB in relation to surrounding components and the number of PCB layers. Connecting the GND balls through thermal vias and into a large ground plane will aid heat extraction.

Three main heat transfer paths exist to surrounding air as illustrated below in Figure 1:

- Package top to air (radiation).
- Package bottom to PCB (radiation).
- Package balls to PCB (conduction).



Figure 1 Heat Transfer Paths

The temperature rise  $T_R$  is given by  $T_R = P_D * \Theta_{JA}$ 

- P<sub>D</sub> is the power dissipated in the device.
- $\Theta_{JA}$  is the thermal resistance from the junction of the die to the ambient temperature and is therefore a measure of heat transfer from the die to surrounding air.  $\Theta_{JA}$  is determined with reference to JEDEC standard JESD51-9.

The junction temperature  $T_J$  is given by  $T_J = T_A + T_R$ , where  $T_A$  is the ambient temperature.

| PARAMETER                      | SYMBOL          | MIN | TYP | MAX | UNIT |
|--------------------------------|-----------------|-----|-----|-----|------|
| Operating temperature range    | T <sub>A</sub>  | -40 |     | 85  | °C   |
| Operating junction temperature | TJ              | -40 |     | 125 | °C   |
| Thermal Resistance             | Өлс             |     | 30  |     | °C/W |
| (Junction to Case)             |                 |     |     |     |      |
| Thermal Resistance             | θ <sub>JA</sub> |     | 60  |     | °C/W |
| (Junction to Ambient)          |                 |     |     |     |      |

### Notes:

 Junction temperature is a function of ambient temperature and of the device operating conditions. The ambient temperature limits and junction temperature limits must both be observed.



## **ELECTRICAL CHARACTERISTICS**

### **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,

 $T_A = +25^{\circ}C$ , 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                                     | SYMBOL         | TEST CONDITIONS                           | MIN | TYP      | MAX      | UNIT        |
|---------------------------------------------------------------|----------------|-------------------------------------------|-----|----------|----------|-------------|
| Analogue Inputs (IN1L, IN                                     | 2L, IN1R, IN2R | )                                         |     |          |          | -           |
| Maximum input signal                                          |                | Single-ended input                        |     | 1.0      |          | Vrms        |
| level (changes in                                             |                |                                           |     | 0        |          | dBV         |
| proportion to LDOVOUT)                                        |                | Pseudo-differential input                 |     | 0.7      |          | Vrms        |
|                                                               |                |                                           |     | -3.1     |          | dBV         |
| Input resistance (IN1L,                                       |                | +35.25dB gain                             |     | 3.5      |          | kΩ          |
| IN1R)                                                         |                | 0dB gain                                  |     | 104      |          | kΩ          |
|                                                               |                | -12dB gain                                |     | 166      |          | kΩ          |
| Input resistance (IN2L, IN2R)                                 |                | All gain settings                         |     | 96       |          | kΩ          |
| Input capacitance                                             |                |                                           |     | 10       |          | pF          |
| Analanus Innuta (ALIVA A                                      | ALIVA)         |                                           |     |          |          |             |
| Analogue Inputs (AUX1, A                                      | AUXZ)          | AUX1 or AUX2 enabled as audio             |     | 1.0      |          | 1/11111     |
| Maximum input signal level (changes in proportion to LDOVOUT) |                | input                                     |     | 1.0<br>0 |          | Vrms<br>dBV |
| Input resistance                                              |                | Input mixer path (0dB)                    |     | 100      |          | kΩ          |
|                                                               |                | Output mixer / direct speaker path (0dB)  |     | 15       |          | kΩ          |
|                                                               |                | Output mixer / direct speaker path (-6dB) |     | 30       |          | kΩ          |
| Input capacitance                                             |                |                                           |     | 10       |          | pF          |
|                                                               |                |                                           |     |          |          |             |
| Analogue Inputs Program                                       | ımable Gain An | nplifiers (PGAs)                          |     |          |          |             |
| Minimum programmable gain                                     |                |                                           |     | -12      |          | dB          |
| Maximum programmable gain                                     |                |                                           |     | 35.25    |          | dB          |
| Gain step size                                                |                | Guaranteed monotonic                      |     | 0.75     |          | dB          |
| Mute attenuation                                              |                |                                           |     | 92       |          | dB          |
| Common Mode<br>Rejection Ratio                                |                | 1kHz input                                |     | 110      |          | dB          |
|                                                               |                |                                           |     |          |          |             |
| Speaker Output Programs                                       | mable Gain Am  | plifiers (PGAs)                           |     |          |          | I           |
| Minimum programmable gain                                     |                |                                           |     | -57      |          | dB          |
| Maximum programmable gain                                     |                |                                           |     | 6        |          | dB          |
| Gain step size                                                |                | Guaranteed monotonic                      |     | 1        |          | dB          |
| Mute attenuation                                              |                |                                           |     | 71       |          | dB          |
| ADC Input Path Performa                                       | nce (Input PGA | as to ADC)                                |     | 1        | <u> </u> |             |
| SNR (A-weighted)                                              |                |                                           | 84  | 94       |          | dB          |
| THD                                                           |                | -1dBFS input                              |     | -83      | -75      | dB          |
| THD+N                                                         |                | -1dBFS input                              |     | -77      | -70      | dB          |
| Channel separation (Left/Right)                               |                | - P                                       |     | 95       |          | dB          |
|                                                               |                |                                           |     |          |          |             |



| PARAMETER                       | SYMBOL           | TEST CONDITIONS                   | MIN            | TYP        | MAX            | UNIT     |
|---------------------------------|------------------|-----------------------------------|----------------|------------|----------------|----------|
| Bypass to Line Output (S        | Single-ended IN2 | L, IN2R to Input PGA to Line Outp | out, 10kΩ / 50 | pF)        |                |          |
| SNR (A-weighted)                |                  | PGA Gain = 0dB                    | 90             | 98         |                | dB       |
|                                 |                  | INPPGAVOL = 0dB                   |                |            |                |          |
| THD+N                           |                  | PGA Gain = 0dB                    |                | -89.5      | -82            | dB       |
|                                 |                  | INPPGAVOL = 0dB                   |                |            |                |          |
|                                 |                  |                                   |                |            |                |          |
| Bypass to Speaker Outp          | ut ( Single-ende | d AUX1, AUX2 to Input PGA to SPI  | KMIX to Spea   | ker Output | , 10kΩ / 50pF) |          |
| SNR (A-weighted)                |                  | PGA Gain = 0dB                    | 90             | 96         |                | dB       |
|                                 |                  | INPPGAVOL = 0dB                   |                |            |                |          |
| THD+N                           |                  | PGA Gain = 0dB                    |                | -86.5      | -77            | dB       |
|                                 |                  | INPPGAVOL = 0dB                   |                |            |                |          |
|                                 |                  |                                   |                |            |                |          |
| DAC Output Path Perform         | nance (DAC to L  | ine Output, 10kΩ / 50pF)          |                |            |                |          |
| Maximum output signal           |                  |                                   |                | 1          |                | Vrms     |
| level (changes in               |                  |                                   |                |            |                |          |
| proportion to LDOVOUT)          |                  |                                   | 0.5            | 00         |                | 40       |
| SNR (A-weighted) THD            |                  |                                   | 85             | 96         | 70             | dB<br>dB |
| THD+N                           |                  |                                   |                | -78<br>-76 | -72<br>-70     | dB<br>dB |
|                                 |                  |                                   |                | -76        | -70            | dB       |
| Channel separation (Left/Right) |                  |                                   |                | 90         |                | dB       |
| Mute attenuation                |                  |                                   |                | 125        |                | dB       |
| PSRR (with respect to           |                  |                                   |                | 48         |                | dB       |
| LDOVDD)                         |                  |                                   |                | 60         |                | ub.      |
| Line Output Resistance          |                  |                                   |                | 10         |                | kΩ       |
| Line Output Capacitance         |                  |                                   |                | 50         |                | pF       |
| Line Output Oupdoitance         |                  |                                   |                | - 00       |                | Pi       |
| DAC Output Path Perform         | nance (DAC to S  | Speaker Output, 10kΩ / 50pF)      |                |            | 1              |          |
| Maximum output signal           |                  | pounds output, rotals outs y      |                | 1          |                | Vrms     |
| level (changes in               |                  |                                   |                |            |                | VIIIIO   |
| proportion to LDOVOUT)          |                  |                                   |                |            |                |          |
| SNR (A-weighted)                |                  |                                   |                | 96         |                | dB       |
| THD                             |                  |                                   |                | -78        |                | dB       |
| THD+N                           |                  |                                   |                | -76        |                | dB       |
|                                 |                  |                                   |                |            |                |          |
| Speaker Output Perform          | ance (Speaker O  | utput, 8Ω BTL)                    |                |            |                |          |
| SNR (A-weighted)                |                  |                                   | 90             | 96         |                | dB       |
| THD                             |                  | P <sub>0</sub> =150mW             |                | 0.03       |                | %        |
|                                 |                  |                                   |                | -68        |                | dB       |
|                                 |                  | P <sub>o</sub> =350mW             |                | 2.944      |                | %        |
|                                 |                  |                                   |                | -30.6      |                | dB       |
| THD+N                           |                  | P <sub>O</sub> =150mW             |                | 0.05       |                | %        |
|                                 |                  |                                   |                | -66        |                | dB       |
|                                 |                  | P <sub>o</sub> =350mW             |                | 3.72       |                | %        |
|                                 |                  |                                   |                | -28.6      |                | dB       |
| Channel separation              |                  |                                   |                | 90         |                | dB       |
| (Left/Right)                    |                  |                                   |                |            |                | 15       |
| Mute attenuation                |                  | 2471                              |                | 92         |                | dB       |
| PSRR (with respect to LDOVDD)   |                  | 217Hz                             |                | 48         |                | dB       |
|                                 |                  | 1kHz                              |                | 60         |                | -10      |
| PSRR (with respect to SPKVDD)   |                  | 217Hz                             |                | 89         |                | dB       |
| ·                               |                  | 1kHz                              |                | 79         |                |          |
| Speaker Resistance              |                  |                                   |                | 8          |                | Ω        |
| Speaker Capacitance             |                  |                                   |                | 50         |                | pF       |



| PARAMETER                                                                                | SYMBOL  | TEST CONDITIONS                                     | MIN       | TYP  | MAX       | UNIT       |
|------------------------------------------------------------------------------------------|---------|-----------------------------------------------------|-----------|------|-----------|------------|
| Digital Inputs/Outputs                                                                   |         |                                                     |           |      |           |            |
| Input high level                                                                         |         |                                                     | 0.7×DBVDD |      |           | V          |
| Input low level                                                                          |         |                                                     |           |      | 0.3×DBVDD | V          |
| Output high level                                                                        |         | I <sub>OL</sub> = 1mA                               | 0.8×DBVDD |      |           | V          |
| Output low level                                                                         |         | I <sub>OH</sub> = -1mA                              |           |      | 0.2×DBVDD | V          |
| Input capacitance                                                                        |         |                                                     |           | 10   |           | pF         |
| Input leakage                                                                            |         | All digital pins except CIFMODE                     | -900      |      | 900       | nA         |
|                                                                                          |         | CIFMODE pin                                         | -90       |      | 90        | nA         |
|                                                                                          |         |                                                     |           |      |           |            |
| LDO Regulator                                                                            |         | -                                                   | *         |      | -1        |            |
| Input voltage                                                                            | LDOVDD  |                                                     | 2.4       | 3.3  | 3.6       | V          |
| Output voltage                                                                           | LDOVOUT | LDO_REF_SEL = 0                                     |           | 3.0  |           | V          |
| Maximum output current                                                                   |         |                                                     |           | 50   |           | mA         |
| (see note)                                                                               |         |                                                     |           |      |           |            |
| Output voltage accuracy                                                                  |         | I <sub>LOAD</sub> = 50mA                            |           | 2    |           | %          |
| Quiescent current                                                                        |         | No Load                                             |           | 55   |           | μА         |
| Leakage current                                                                          |         |                                                     |           | 1    | 1         | μA         |
| PSRR (with respect to                                                                    |         | 217Hz                                               |           | 40   | 1         | dB         |
| LDOVDD)                                                                                  |         | 1kHz                                                |           | 49   |           |            |
|                                                                                          |         |                                                     | †         |      | †         |            |
| Video Buffer                                                                             | I.      | 1                                                   | 1         |      |           |            |
| Maximum output voltage                                                                   | Vom     | f=100kHz, THD=1%                                    | 1.10      | 1.25 | 1.50      | V pk-pk    |
| swing                                                                                    |         |                                                     |           |      |           |            |
| Voltage gain                                                                             | Av      | VB_GAIN = 1, $R_{REF}$ =187 $\Omega$ ,              | 5.08      | 6    | 7.94      | dB         |
|                                                                                          |         | $R_{LOAD}$ =75 $\Omega$ , $R_{SOURCE}$ =75 $\Omega$ |           |      |           |            |
|                                                                                          |         | VB_GAIN = 0, $R_{REF}$ =187 $\Omega$ ,              | -0.92     | 0    | 1.94      | dB         |
|                                                                                          |         | $R_{LOAD}$ =75 $\Omega$ , $R_{SOURCE}$ =75 $\Omega$ |           |      |           |            |
| Gain step size                                                                           |         |                                                     |           | 6    |           | dB         |
| Differential gain                                                                        | DG      | Vin = 1V pk-pk                                      | -2.0      | 0.3  | +2.0      | %          |
| Differential phase                                                                       | DP      | Vin = 1V pk-pk                                      | -2.0%     | 0.7  | +2.0      | Deg        |
| SNR                                                                                      | VSNR    |                                                     | 40        | 60   | 100       | dB         |
| SYNC tip offset above                                                                    |         | VB_PD = 0                                           | 0         | 40   | 75        | mV         |
| GND                                                                                      |         | VB_GAIN = 1                                         |           |      |           |            |
| Third order Low Pass                                                                     |         | 2.4MHz                                              | -0.5      | 0    | 0.5       | dB         |
| Filter response                                                                          |         | 5.13MHz                                             | -0.5      | -0.2 | 0.5       | dB         |
| (referenced to 100kHz)                                                                   |         | 9.04MHz                                             | -3.0      | -1.6 | 0         | dB         |
| $R_{REF}$ =187 $\Omega$ , $R_{LOAD}$ =75 $\Omega$ , $R_{SOURCE}$ =75 $\Omega$ , 0dB gain |         | 13.32MHz                                            | -11.0     | -7.0 | -3.0      | dB         |
| PSRR (with respect to                                                                    |         | 100kHz                                              | +         | 60   | +         | dB         |
| LDOVOUT)                                                                                 |         | . 33                                                |           | -    |           | 45         |
| ·                                                                                        |         |                                                     |           |      |           |            |
| Clocking                                                                                 |         | •                                                   |           |      |           |            |
| MCLK frequency                                                                           |         |                                                     | 30Hz      |      | 27MHz     | Hz         |
| FLL output frequency                                                                     |         |                                                     | 2.045     |      | 50        | MHz        |
| FLL lock time                                                                            |         |                                                     |           | 2    | 1         | ms         |
|                                                                                          |         |                                                     |           |      |           |            |
| MICBIAS                                                                                  |         | •                                                   | <u> </u>  |      |           |            |
| Bias voltage (changes in                                                                 | MICBIAS | MICB LVL = 0                                        |           | 2.7  |           | V          |
| proportion to LDOVOUT)                                                                   |         | MICB_LVL = 1                                        | +         | 1.95 | +         |            |
| Bias Current source                                                                      |         |                                                     | +         |      | 3         | mA         |
| Output noise spectral                                                                    |         | 1kHz to 20kHz                                       | + +       | 15   | +         | nV/√Hz     |
| density                                                                                  |         | THE IZ TO ZOIN IZ                                   |           | 10   |           | IIV/ VI IZ |
| PSRR (with respect to                                                                    |         | 217Hz                                               | 1         | 70   | 1         | dB         |
|                                                                                          |         |                                                     |           |      |           |            |



| PARAMETER                                                          | SYMBOL | TEST CONDITIONS                 | MIN  | TYP | MAX  | UNIT     |
|--------------------------------------------------------------------|--------|---------------------------------|------|-----|------|----------|
| Analogue Reference Lev                                             | els    |                                 |      |     |      |          |
| Midrail Reference<br>Voltage (changes in<br>proportion to LDOVOUT) | VMID   | VMID_REF_SEL = 1<br>VMID_CTRL=1 |      | 1.5 |      | <b>V</b> |
| Bandgap Reference                                                  |        | BG_VSEL=01010                   | -10% | 1.5 | +10% | V        |

#### Note:

The maximum LDO output current is the total internal and external load capability; internal circuits of the WM8946 will typically account for 25mA of this capacity.

### **TERMINOLOGY**

- Signal-to-Noise Ratio (dB) SNR is the difference in level between a full scale output signal and the device output noise with no signal applied, measured over a bandwidth of 20Hz to 20kHz. This ratio is also called idle channel noise. (No Auto-zero or Mute function is employed).
- 2. Total Harmonic Distortion (dB) THD is the difference in level between a 1kHz reference sine wave output signal and the first seven harmonics of the output signal. The amplitude of the fundamental frequency of the output signal is compared to the RMS value of the next seven harmonics and expressed as a ratio.
- 3. Total Harmonic Distortion plus Noise (dB) THD+N is the difference in level between a 1kHz reference sine wave output signal and all noise and distortion products in the audio band. The amplitude of the fundamental reference frequency of the output signal is compared to the RMS value of all other noise and distortion products and expressed as a ratio.
- 4. Channel Separation (L/R) (dB) is a measure of the coupling between left and right channels. A full scale signal is applied to the left channel only, and the right channel amplitude is measured. Next, a full scale signal is applied to the right channel only, and the left channel amplitude is measured. The worst case channel separation is quoted; this is the difference in level between the full-scale output and the cross-channel output signal level, expressed as a ratio.
- 5. Mute Attenuation This is a measure of the difference in level between the full scale output signal and the output with mute applied.
- 6. Power Supply Rejection Ratio (dB) PSRR is a measure of ripple attenuation between a power supply rail and a signal output path. With the signal path idle, a small sine wave ripple is applied to power supply rail. The amplitude of the supply ripple is compared to the amplitude of the output signal generated and is expressed as a ratio.
- 7. All performance measurements are carried out with 20kHz AES17 low pass filter for distortion measurements, and an A-weighted filter for noise measurement. Failure to use such a filter will result in higher THD and lower SNR and Dynamic Range readings than are found in the Electrical Characteristics. The low pass filter removes out-of-band noise; although it is not audible, it may affect dynamic specification values.



## **TYPICAL PERFORMANCE**

WM8946 ADC - THD+N v Ampltiude - ADC - Slave Mode





WM8946 - DAC to SPKOUT 80hm BTL THD+N v Amplitude - 48kHz





# **POWER CONSUMPTION**

Typical power consumption

|                                           | DCVDD | DBVDD | LDOVDD | SPKVDD | Total        | Total      |
|-------------------------------------------|-------|-------|--------|--------|--------------|------------|
| Condition                                 | 1.8   | 3.3   | 3.3    | 3.3    | Current (mA) | Power (mW) |
| Powerdown (no data)                       | 0.178 | 0.062 | 0.007  | 0.002  | 0.267        | 0.555      |
| Powerdown (+Master BIAS)                  | 0.178 | 0.062 | 0.021  | 0.002  | 0.282        | 0.603      |
| Powerdown (+Master BIAS+VMID buffer)      | 0.178 | 0.062 | 0.142  | 0.002  | 0.403        | 1.001      |
| Powerdown (+Master BIAS+VMID buffer+VMID) | 0.178 | 0.063 | 1.092  | 0.002  | 1.353        | 4.137      |
| Playback to Lineout (no data)             | 4.272 | 0.057 | 2.336  | 0.007  | 6.672        | 15.609     |
| Playback to Lineout (with data)           | 4.293 | 0.062 | 2.356  | 0.007  | 6.718        | 15.728     |
| Video Buffer Only                         | 0.178 | 0.062 | 5.088  | 0.020  | 5.348        | 17.380     |
| Playback to Speaker (no data)             | 4.272 | 0.057 | 2.877  | 4.707  | 11.647       | 32.904     |
| Playback to Speaker (with data)           | 4.294 | 0.062 | 2.895  | 4.730  | 11.696       | 33.095     |
| Playback to Speaker (with data) 32ohm     | 4.295 | 0.062 | 2.895  | 5.790  | 13.042       | 36.595     |
| Playback to Speaker (with data) 16ohm     | 4.295 | 0.062 | 2.896  | 6.275  | 13.528       | 38.199     |
| Mono Record (nodata)                      | 2.992 | 0.088 | 3.728  | 0.007  | 6.815        | 18.001     |
| Mono Record (with data)                   | 2.999 | 0.100 | 3.727  | 0.007  | 6.833        | 18.049     |
| Stereo Record (no data)                   | 4.652 | 0.128 | 6.692  | 0.007  | 11.479       | 30.903     |
| Stereo Record (with data)                 | 4.654 | 0.128 | 6.692  | 0.007  | 11.481       | 30.907     |
| Playback and Record (no data)             | 5.673 | 0.120 | 10.054 | 4.408  | 20.255       | 58.333     |
| All On                                    | 5.408 | 0.099 | 62.323 | 4.211  | 72.041       | 229.622    |



## **AUDIO SIGNAL PATHS DIAGRAM**



# **SIGNAL TIMING REQUIREMENTS**

## **SYSTEM CLOCK TIMING**



Figure 2 Master Clock Timing

### **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V, T<sub>A</sub> = +25°C.

| PARAMETER                                    | SYMBOL             | CONDITIONS | MIN     | TYP | MAX   | UNIT |
|----------------------------------------------|--------------------|------------|---------|-----|-------|------|
| Master Clock Timing                          |                    |            |         |     |       |      |
| MCLK cycle time                              | T <sub>MCLKY</sub> |            | 0.037μs |     |       | S    |
| MCLK duty cycle                              |                    |            | 60:40   |     | 40:60 |      |
| (= T <sub>MCLKH</sub> : T <sub>MCLKL</sub> ) |                    |            |         |     |       |      |

## **AUDIO INTERFACE TIMING**

## **MASTER MODE**



Figure 3 Audio Interface Timing - Master Mode

## **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,

 $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                       | SYMBOL           | MIN | TYP | MAX | UNIT |
|-------------------------------------------------|------------------|-----|-----|-----|------|
| Audio Interface Timing - Master Mode            |                  |     |     |     |      |
| LRCLK propagation delay from BCLK falling edge  | t <sub>DL</sub>  |     |     | 20  | ns   |
| ADCDAT propagation delay from BCLK falling edge | t <sub>DDA</sub> |     |     | 20  | ns   |
| DACDAT setup time to BCLK rising edge           | t <sub>DST</sub> | 20  |     |     | ns   |
| DACDAT hold time from BCLK rising edge          | t <sub>DHT</sub> | 10  |     |     | ns   |

## **SLAVE MODE**



Figure 4 Audio Interface Timing - Slave Mode

## **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,  $T_A = +25$ °C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                       | SYMBOL            | MIN | TYP | MAX | UNIT |
|-------------------------------------------------|-------------------|-----|-----|-----|------|
| Audio Interface Timing - Slave Mode             |                   |     |     |     |      |
| BCLK cycle time                                 | t <sub>BCY</sub>  | 50  |     |     | ns   |
| BCLK pulse width high                           | t <sub>BCH</sub>  | 20  |     |     | ns   |
| BCLK pulse width low                            | t <sub>BCL</sub>  | 20  |     |     | ns   |
| LRCLK set-up time to BCLK rising edge           | t <sub>LRSU</sub> | 20  |     |     | ns   |
| LRCLK hold time from BCLK rising edge           | t <sub>LRH</sub>  | 10  |     |     | ns   |
| DACDAT hold time from BCLK rising edge          | t <sub>DH</sub>   | 10  |     |     | ns   |
| ADCDAT propagation delay from BCLK falling edge | t <sub>DD</sub>   |     |     | 20  | ns   |
| DACDAT set-up time to BCLK rising edge          | t <sub>DS</sub>   | 20  |     |     | ns   |

 $\textbf{Note:} \ \mathsf{BCLK} \ \mathsf{period} \ \mathsf{must} \ \mathsf{always} \ \mathsf{be} \ \mathsf{greater} \ \mathsf{than} \ \mathsf{or} \ \mathsf{equal} \ \mathsf{to} \ \mathsf{MCLK} \ \mathsf{period}.$ 

## **CONTROL INTERFACE TIMING**



Figure 5 Control Interface Timing - 2-wire (I2C) Control Mode

## **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,  $T_A = +25^{\circ}C$ , 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                     | SYMBOL          | MIN  | TYP | MAX | UNIT |
|-----------------------------------------------|-----------------|------|-----|-----|------|
| SCLK Frequency                                |                 |      |     | 400 | kHz  |
| SCLK Low Pulse-Width                          | t <sub>1</sub>  | 1300 |     |     | ns   |
| SCLK High Pulse-Width                         | t <sub>2</sub>  | 600  |     |     | ns   |
| Hold Time (Start Condition)                   | t <sub>3</sub>  | 600  |     |     | ns   |
| Setup Time (Start Condition)                  | t <sub>4</sub>  | 600  |     |     | ns   |
| Data Setup Time                               | t <sub>5</sub>  | 100  |     |     | ns   |
| SDA, SCLK Rise Time                           | t <sub>6</sub>  |      |     | 300 | ns   |
| SDA, SCLK Fall Time                           | t <sub>7</sub>  |      |     | 300 | ns   |
| Setup Time (Stop Condition)                   | t <sub>8</sub>  | 600  |     |     | ns   |
| Data Hold Time                                | t <sub>9</sub>  |      |     | 900 | ns   |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub> | 0    |     | 5   | ns   |





Figure 6 Control Interface Timing - 3-wire (SPI) Control Mode (Write Cycle)

Note: The data is latched on the 32<sup>nd</sup> falling edge of SCLK after 32 bits have been clocked into the device.



Figure 7 Control Interface Timing - 3-wire (SPI) Control Mode (Read Cycle)

### **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,  $T_A = +25^{\circ}C$ , 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                     | SYMBOL           | MIN | TYP | MAX | UNIT |
|-----------------------------------------------|------------------|-----|-----|-----|------|
| CS falling edge to SCLK rising edge           | t <sub>csu</sub> | 40  |     |     | ns   |
| SCLK falling edge to CS rising edge           | t <sub>сно</sub> | 10  |     |     | ns   |
| SCLK pulse cycle time                         | t <sub>scy</sub> | 200 |     |     | ns   |
| SCLK pulse width low                          | t <sub>scl</sub> | 80  |     |     | ns   |
| SCLK pulse width high                         | t <sub>scн</sub> | 80  |     |     | ns   |
| SDA to SCLK set-up time                       | t <sub>DSU</sub> | 40  |     |     | ns   |
| SDA to SCLK hold time                         | t <sub>DHO</sub> | 10  |     |     | ns   |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub>  | 0   |     | 5   | ns   |
| SCLK falling edge to SDA output transition    | t <sub>DL</sub>  |     |     | 40  | ns   |



Figure 8 Control Interface Timing - 4-wire (SPI) Control Mode (Write Cycle)

Note: The data is latched on the 32<sup>nd</sup> falling edge of SCLK after 32 bits have been clocked into the device.



Figure 9 Control Interface Timing - 4-wire (SPI) Control Mode (Read Cycle)

#### **Test Conditions**

DCVDD = 1.8V, DBVDD = LDOVDD = SPKVDD = 3.3V, LDOVOUT = 3.0V, GND = 0V,  $T_A = +25^{\circ}C$ , 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                     | SYMBOL           | MIN | TYP | MAX | UNIT |
|-----------------------------------------------|------------------|-----|-----|-----|------|
| CS falling edge to SCLK rising edge           | t <sub>csu</sub> | 40  |     |     | ns   |
| SCLK falling edge to CS rising edge           | t <sub>CHO</sub> | 10  |     |     | ns   |
| SCLK pulse cycle time                         | t <sub>scy</sub> | 200 |     |     | ns   |
| SCLK pulse width low                          | t <sub>scl</sub> | 80  |     |     | ns   |
| SCLK pulse width high                         | t <sub>sch</sub> | 80  |     |     | ns   |
| SDA to SCLK set-up time                       | t <sub>DSU</sub> | 40  |     |     | ns   |
| SDA to SCLK hold time                         | t <sub>DHO</sub> | 10  |     |     | ns   |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub>  | 0   |     | 5   | ns   |
| SCLK falling edge to SDOUT transition         | t <sub>DL</sub>  |     |     | 40  | ns   |

WM8946 Production Data

### **DEVICE DESCRIPTION**

### INTRODUCTION

The WM8946 is a highly integrated low power hi-fi CODEC designed for portable devices such as digital still cameras and multimedia phones. Flexible analogue interfaces and powerful digital signal processing (DSP) in a 2.96 x 3.06mm footprint make it ideal for small portable devices.

The WM8946 supports up to 6 analogue audio inputs. One pair of single-ended or pseudo differential microphone / line inputs is selected as the ADC input source. The two auxiliary inputs can be selected as line inputs to the ADC, or as direct signal paths to the output mixers. An integrated bias reference is provided to power standard electret microphones. A two-channel digital microphone interface is also supported, with direct input to the DSP core via the ADCs.

The stereo hi-fi ADCs and DACs operate at sample rates from 8kHz up to 48kHz. A high pass filter is available in the ADC path for removing DC offsets and suppressing low frequency noise such as mechanical vibration and wind noise. A digital tone ('beep') generator allows audio tones to be injected into the DAC output path.

The WM8946 provides a powerful DSP capability for configurable filtering and processing of the digital audio paths. The DSP provides low-pass / high-pass filtering, 3D stereo enhancement, notch filters, 5-band EQ, dynamic range control and a programmable DF1 digital filter. The tuned notch filters allow narrow frequency bands to be attenuated, to provide filtering of motor noise or other unwanted sounds; the 5-band EQ allows the signal to be adjusted for user-preferences. The dynamic range control provides a range of compression, limiting and noise gate functions to support optimum configuration for recording or playback modes. The DF1 filter allows user-specified algorithms to be implemented in the digital signal chain.

The Wolfson ReTune™ feature is a highly-configurable DSP algorithm which can be tailored to cancel or compensate for imperfect characteristics of the housing, loudspeaker or microphone components in the target application. The ReTune™ algorithm coefficients and register contents are calculated using Wolfson's WISCE™ software; lab bench tests and audio reference measurements must be performed in order to determine the optimum settings.

The digital signal routing between the ADCs, DACs and I2S digital audio interface can be configured in different ways according to the application requirements. The DSP functions may be applied to the ADC record path, or the DAC record path, or may be distributed between these two paths.

Four analogue output mixers are provided, connected to 4 analogue output pins. Twin stereo outputs or stereo headphone/line and mono BTL speaker may be connected to these outputs.

The WM8946 incorporates an LDO regulator for compatibility with a wide range of supply rails; the internal LDO can also reduce any interference resulting from a noisy supply rail. The LDO regulator can also be used to provide a regulated supply voltage to other circuits.

I2C or SPI control interface modes for read/write access to the register map. A single external clock provides timing reference for all the digital functions; an integrated Frequency Locked Loop (FLL) also provides flexibility to perform frequency conversions and to remove noise/jitter from the external clock. The FLL can be configured for reduced power consumption, or for different filtering requirements of the reference source.

Additional functions include a current-mode video buffer providing excellent video signal reproduction at low operating voltages. Up to 4 GPIO pins may be configured for miscellaneous input/output, or for status indications from the temperature monitoring functions.



## **ANALOGUE INPUT SIGNAL PATH**

The WM8946 has six analogue input pins, which may be selected in many different configurations. The analogue input paths can support line and microphone inputs, in single-ended or pseudo-differential modes. The auxiliary input pins (AUX1 and AUX2) may be configured as inputs to the input PGAs or to the output mixers.

The Left and Right input PGA audio channels are routed to the Analogue to Digital converters (ADCs). There is also a bypass path for each channel, enabling the signal to be routed directly to the output mixers.

The WM8946 input signal paths and control registers are illustrated in Figure 10.



Figure 10 Input Signal Paths

### **INPUT PGA ENABLE**

The input PGAs (Programmable Gain Amplifiers) are enabled using register bits INPPGAR\_ENA and INPPGAL\_ENA, as described in Table 1.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION            |
|---------------------|-----|-------------|---------|------------------------|
| R2 (02h)            | 13  | INPPGAR_ENA | 0       | Right Input PGA Enable |
| Power               |     |             |         | 0 = Disabled           |
| Management 1        |     |             |         | 1 = Enabled            |
|                     | 12  | INPPGAL_ENA | 0       | Left Input PGA Enable  |
|                     |     |             |         | 0 = Disabled           |
|                     |     |             |         | 1 = Enabled            |

Table 1 Input PGA Enable

To enable the input PGAs, the reference voltage VMID and the bias current must also be enabled. See "Reference Voltages and Master Bias" for details of the associated controls VMID\_SEL and BIAS ENA.

### **INPUT PGA CONFIGURATION**

Microphone and Line level audio inputs can be connected to the WM8946 in single-ended or differential configurations. (These two configurations are illustrated in Figure 58 and Figure 59 in the section describing the external components requirements - see "Applications Information".)

For single-ended microphone inputs, the microphone signal is connected to the non-inverting input of the PGAs, whilst the inverting inputs of the PGAs are connected to VMID. For differential microphone inputs, the non-inverted microphone signal is connected to the non-inverting input of the PGAs, whilst the inverted (or 'noisy ground') signal is connected to the inverting input pins.

Line level inputs are connected in the same way as a single-ended microphone signal.

The non-inverting input of the PGAs is configured using the P\_PGAR\_SEL and P\_PGAL\_SEL registers. These registers allow the selection of three possible input pins to the associated PGA. When the AUX1 or AUX2 pin is used as an audio input, that pin must be configured for audio using the AUX1\_AUDIO or AUX2\_AUDIO register bits.

The inverting input of the PGAs is configured using MICRN\_TO\_N\_PGAR and MICLN\_TO\_N\_PGAL. These registers allow the PGA to operate in either single-ended or pseudo-differential configuration.

The registers for configuring the Input PGAs are described in Table 2.

| REGISTER<br>ADDRESS | BIT | LABEL               | DEFAULT | DESCRIPTION                              |
|---------------------|-----|---------------------|---------|------------------------------------------|
| R39 (27h)           | 8   | AUX2_AUDIO          | 0       | AUX2 pin configuration                   |
| Input Ctrl          |     |                     |         | 0 = Non-Audio signal                     |
|                     |     |                     |         | 1 = AC-coupled Audio signal              |
|                     | 7   | AUX1_AUDIO          | 0       | AUX1 pin configuration                   |
|                     |     |                     |         | 0 = Non-Audio signal                     |
|                     |     |                     |         | 1 = AC-coupled Audio signal              |
|                     | 5   | MICRN_TO_N_<br>PGAR | 1       | Right Input PGA Inverting Input Select   |
|                     |     |                     |         | 0 = Connected to VMID                    |
|                     |     |                     |         | 1 = Connected to IN2R                    |
|                     | 4   | MICLN_TO_N_P<br>GAL | 1       | Left Input PGA Inverting Input<br>Select |
|                     |     |                     |         | 0 = Connected to VMID                    |
|                     |     |                     |         | 1 = Connected to IN2L                    |



| REGISTER<br>ADDRESS | BIT | LABEL               | DEFAULT | DESCRIPTION                                  |
|---------------------|-----|---------------------|---------|----------------------------------------------|
|                     | 3:2 | P_PGAR_SEL<br>[1:0] | 01      | Right Input PGA Non-Inverting Input Select   |
|                     |     |                     |         | 00 = Connected to IN2R                       |
|                     |     |                     |         | 01 = Connected to IN1R                       |
|                     |     |                     |         | 10 = Connected to AUX2                       |
|                     |     |                     |         | 11 = Reserved                                |
|                     | 1:0 | P_PGAL_SEL<br>[1:0] | 01      | Left Input PGA Non-Inverting Input<br>Select |
|                     |     |                     |         | 00 = Connected to IN2L                       |
|                     |     |                     |         | 01 = Connected to IN1L                       |
|                     |     |                     |         | 10 = Connected to AUX1                       |
|                     |     |                     |         | 11 = Reserved                                |

**Table 2 Input PGA Configuration** 

### MICROPHONE BIAS CONTROL

The WM8946 provides a low noise reference voltage suitable for biasing electret condenser (ECM) type microphones via an external resistor. Refer to the "Applications Information" section for recommended components. The MICBIAS voltage is enabled using the MICB\_ENA register bit; the voltage can be selected using the MICB LVL bit, as described in Table 3.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                     |
|---------------------|-----|----------|---------|---------------------------------|
| R2 (02h)            | 4   | MICB_ENA | 0       | Microphone Bias Enable          |
| Power               |     |          |         | 0 = Disabled                    |
| Management 1        |     |          |         | 1 = Enabled                     |
| R39 (27h)           | 6   | MICB_LVL | 0       | Microphone Bias Voltage control |
| Input Ctrl          |     |          |         | 0 = 0.9 x LDOVOUT               |
|                     |     |          |         | 1 = 0.65 x LDOVOUT              |

**Table 3 Microphone Bias Control** 

#### **INPUT PGA GAIN CONTROL**

The volume control gain for the Left and Right channels can be independently adjusted using the PGAL\_VOL and PGAR\_VOL register fields as described in Table 4. The gain range is -12dB to +35.25dB in 0.75dB steps. The gains on the inverting and non-inverting inputs to the PGAs are always equal. Each input PGA can be independently muted using the PGA mute bits.

To prevent "zipper noise", a zero-cross function is provided on the input PGAs. When this feature is enabled, volume updates will not take place until a zero-crossing is detected. In the case of a long period without zero-crossings, a timeout function is provided. When the zero-cross function is enabled, the volume will update after the timeout period if no earlier zero-cross has occurred. The timeout clock is enabled using TOCLK\_ENA. See "Clocking and Sample Rates" for the definition of this bit. Note that the zero-cross function can be supported without TOCLK enabled, but the timeout function will not be provided in this case.

The PGA\_VU bits control the loading of the input PGA volume data. When PGA\_VU is set to 0, the PGA volume data will be loaded into the respective control register, but will not actually change the gain setting. The left and right input PGA volume settings are both updated when a 1 is written to PGA\_VU; this makes it possible to update the gain of the left and right signal paths simultaneously.

Note that SYSCLK must be enabled when writing to the PGA\_VU bits. (See "Clocking and Sample Rates" for details of SYSCLK.)



The Input PGA volume control register fields are described in Table 4.

| REGISTER<br>ADDRESS                     | BIT | LABEL             | DEFAULT          | DESCRIPTION                                                                                                                    |
|-----------------------------------------|-----|-------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------|
| R40 (28h)<br>Left INP PGA<br>gain ctrl  | 8   | PGA_VU            | 0                | Input PGA Volume Update Writing a 1 to this bit will cause the Left and Right Input PGA volumes to be updated simultaneously.  |
|                                         | 7   | PGAL_ZC           | 0                | Left Input PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                              |
|                                         | 6   | PGAL_MUTE         | 1                | Left Input PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                           |
|                                         | 5:0 | PGAL_VOL [5:0]    | 01_0000<br>(0dB) | Left Input PGA Volume  00_0000 = -12dB  00_0001 = -11.25dB   01_0000 = 0dB   11_1111 = +35.25  (See Table 5 for volume range)  |
| R41 (29h)<br>Right INP PGA<br>gain ctrl | 8   | PGA_VU            | 0                | Input PGA Volume Update Writing a 1 to this bit will cause the Left and Right Input PGA volumes to be updated simultaneously.  |
|                                         | 7   | PGAR_ZC           | 0                | Right Input PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                             |
|                                         | 6   | PGAR_MUTE         | 1                | Right Input PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                          |
|                                         | 5:0 | PGAR_VOL<br>[5:0] | 01_0000<br>(0dB) | Right Input PGA Volume  00_0000 = -12dB  00_0001 = -11.25dB   01_0000 = 0dB   11_1111 = +35.25  (See Table 5 for volume range) |

Table 4 Input PGA Volume Control

| PGAL_VOL[5:0],<br>PGAR_VOL[5:0] | VOLUME<br>(dB) | PGAL_VOL[5:0],<br>PGAR_VOL[5:0] | VOLUME<br>(dB) |
|---------------------------------|----------------|---------------------------------|----------------|
| 00_0000                         | -12            | 10_0000                         | 12             |
| 00_0001                         | -11.25         | 10_0001                         | 12.75          |
| 00_0010                         | -10.5          | 10_0010                         | 13.5           |
| 00_0011                         | -9.75          | 10_0011                         | 14.25          |
| 00_0100                         | -9             | 10_0100                         | 15             |
| 00_0101                         | -8.25          | 10_0101                         | 15.75          |
| 00_0110                         | -7.5           | 10_0110                         | 16.5           |
| 00_0111                         | -6.75          | 10_0111                         | 17.25          |
| 00_1000                         | -6             | 10_1000                         | 18             |
| 00_1001                         | -5.25          | 10_1001                         | 18.75          |
| 00_1010                         | -4.5           | 10_1010                         | 19.5           |
| 00_1011                         | -3.75          | 10_1011                         | 20.25          |
| 00_1100                         | -3             | 10_1100                         | 21             |
| 00_1101                         | -2.25          | 10_1101                         | 21.75          |
| 00_1110                         | -1.5           | 10_1110                         | 22.5           |
| 00_1111                         | -0.75          | 10_1111                         | 23.25          |
| 01_0000                         | 0              | 11_0000                         | 24             |
| 01_0001                         | 0.75           | 11_0001                         | 24.75          |
| 01_0010                         | 1.5            | 11_0010                         | 25.5           |
| 01_0011                         | 2.25           | 11_0011                         | 26.25          |
| 01_0100                         | 3              | 11_0100                         | 27             |
| 01_0101                         | 3.75           | 11_0101                         | 27.75          |
| 01_0110                         | 4.5            | 11_0110                         | 28.5           |
| 01_0111                         | 5.25           | 11_0111                         | 29.25          |
| 01_1000                         | 6              | 11_1000                         | 30             |
| 01_1001                         | 6.75           | 11_1001                         | 30.75          |
| 01_1010                         | 7.5            | 11_1010                         | 31.5           |
| 01_1011                         | 8.25           | 11_1011                         | 32.25          |
| 01_1100                         | 9              | 11_1100                         | 33             |
| 01_1101                         | 9.75           | 11_1101                         | 33.75          |
| 01_1110                         | 10.5           | 11_1110                         | 34.5           |
| 01_1111                         | 11.25          | 11_1111                         | 35.25          |

Table 5 Input PGA Volume Range

WM8946 Production Data

## **DIGITAL MICROPHONE INTERFACE**

The WM8946 supports a two-channel digital microphone interface. The two-channel audio data is multiplexed on the IN1L input pin and clocked using a GPIO output. The analogue signal path from the IN1L pin must be disabled when using the digital microphone interface; this is achieved by disabling the associated input PGA, (i.e. INPPGAL\_ENA= 0).

The Digital Microphone Input, DMICDAT, is provided on the IN1L/DMICDAT pin. The associated clock, DMICCLK, is provided on a GPIO pin.

The Digital Microphone Input is selected as input by setting the DMIC\_ENA bit. When the Digital Microphone Input is selected, the ADC input is deselected.

The digital microphone interface configuration is illustrated in Figure 11.

Note that the digital microphone may be powered from MICBIAS or from LDOVOUT; care must be taken to ensure that the respective digital logic levels of the microphone are compatible with the digital input thresholds of the WM8946. The digital input thresholds are referenced to DBVDD, as defined in "Electrical Characteristics".



Figure 11 Digital Microphone Interface

When any GPIO pin is configured as DMICCLK output, the WM8946 outputs a clock which supports Digital Mic operation at the ADC sampling rate. The ADC and Record Path filters must be enabled and the ADC sampling rate must be set in order to ensure correct operation of all DSP functions associated with the digital microphone. Volume control for the Digital Microphone Interface signals is provided using the ADC Volume Control.

See "Analogue-to-Digital Converter (ADC)" for details of the ADC Enable and volume control functions. See "General Purpose Input / Output" for details of configuring the DMICCLK output. See "Clocking and Sample Rates" for the details of the sample rate control.

When the DMIC\_ENA bit is set, then the IN1L pin is used as the digital microphone input DMICDAT. Up to two microphones can share this pin; the two microphones are interleaved as illustrated in Figure 12.

The digital microphone interface requires that MIC1 (Left Channel) transmits a data bit each time that DMICCLK is high, and MIC2 (Right Channel) transmits when DMICCLK is low. The WM8946 samples the digital microphone data in the middle of each DMICCLK clock phase. Each microphone must tristate its data output when the other microphone is transmitting.



Figure 12 Digital Microphone Interface Timing

The digital microphone interface control fields are described in Table 6.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                            |
|---------------------|-----|----------|---------|------------------------------------------------------------------------|
| R2 (02h)            | 7   | DMIC_ENA | 0       | Enables Digital Microphone mode                                        |
| Power               |     |          |         | 0 = Audio DSP input is from ADC                                        |
| Management 1        |     |          |         | 1 = Audio DSP input is from digital microphone interface               |
|                     |     |          |         | When DMIC_ENA = 0, the Digital microphone clock (DMICCLK) is held low. |

**Table 6 Digital Microphone Interface Control** 

# **ANALOGUE-TO-DIGITAL CONVERTER (ADC)**

The WM8946 uses two 24-bit sigma-delta ADCs. The use of multi-bit feedback and high oversampling rates reduces the effects of jitter and high frequency noise. The ADC full-scale input level is proportional to LDOVOUT. See "Electrical Characteristics" section for further details. Any input signal greater than full scale may overload the ADC and cause distortion.

The ADCs and associated digital record filters are enabled by the ADCL\_ENA and ADCR\_ENA register bits.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                      |
|---------------------|-----|----------|---------|--------------------------------------------------------------------------------------------------|
| R2 (02h)            | 11  | ADCR_ENA | 0       | Right ADC Enable                                                                                 |
| Power               |     |          |         | 0 = Disabled                                                                                     |
| Management          |     |          |         | 1 = Enabled                                                                                      |
| 1                   |     |          |         | ADCR_ENA must be set to 1 when processing right channel data from the ADC or Digital Microphone. |
|                     | 10  | ADCL_ENA | 0       | Left ADC Enable                                                                                  |
|                     |     |          |         | 0 = Disabled                                                                                     |
|                     |     |          |         | 1 = Enabled                                                                                      |
|                     |     |          |         | ADCL_ENA must be set to 1 when processing left channel data from the ADC or Digital Microphone.  |

**Table 7 ADC Enable Control** 



### ADC VOLUME CONTROL

The output of the ADCs can be digitally amplified or attenuated over a range from -71.625dB to +23.625dB in 0.375dB steps. The volume of each channel can be controlled separately using ADCL\_VOL or ADCR\_VOL. The ADC Volume is part of the ADC Digital Filters block. The gain for a given eight-bit code X is given by:

 $0.375 \times (X-192) \text{ dB for } 1 \le X \le 255;$  MUTE for X = 0

The ADC\_VU bit controls the loading of digital volume control data. When ADC\_VU is set to 0, the ADCL\_VOL or ADCR\_VOL control data is loaded into the respective control register, but does not actually change the digital gain setting. Both left and right gain settings are updated when a 1 is written to ADC\_VU. This makes it possible to update the gain of both channels simultaneously.

The output of the ADCs can be digitally muted using the ADCL\_MUTE or ADCR\_MUTE bits. Both ADCs are muted simultaneously when the ADC\_MUTEALL bit is set.

| REGISTER<br>ADDRESS      | BIT | LABEL          | DEFAULT   | DESCRIPTION                                                                                     |
|--------------------------|-----|----------------|-----------|-------------------------------------------------------------------------------------------------|
| R25 (19h)                | 8   | ADC_MUTEALL    | 0         | ADC Digital Mute for All Channels                                                               |
| ADC Control 1            |     |                |           | 0 = Disable Mute                                                                                |
|                          |     |                |           | 1 = Enable Mute on all channels                                                                 |
| R27 (1Bh)                | 12  | ADC_VU         | 0         | ADC Volume Update                                                                               |
| Left ADC<br>Digital Vol  |     |                |           | Writing a 1 to this bit will cause<br>Left and Right ADC volume to be<br>updated simultaneously |
|                          | 8   | ADCL_MUTE      | 0         | Left ADC Digital Mute                                                                           |
|                          |     |                |           | 0 = Disable Mute                                                                                |
|                          |     |                |           | 1 = Enable Mute                                                                                 |
|                          | 7:0 | ADCL_VOL [7:0] | 1100_0000 | Left ADC Digital Volume                                                                         |
|                          |     |                | (0dB)     | 0000_0000 = mute                                                                                |
|                          |     |                |           | 0000_0001 = -71.625dB                                                                           |
|                          |     |                |           | 0000_0010 = -71.250dB                                                                           |
|                          |     |                |           |                                                                                                 |
|                          |     |                |           | 1100_0000 = 0dB                                                                                 |
|                          |     |                |           |                                                                                                 |
|                          |     |                |           | 1111_1111 = +23.625dB                                                                           |
|                          |     |                |           | (See Table 9 for volume range)                                                                  |
| R28 (1Ch)                | 12  | ADC_VU         | 0         | ADC Volume Update                                                                               |
| Right ADC<br>Digital Vol |     |                |           | Writing a 1 to this bit will cause<br>Left and Right ADC volume to be<br>updated simultaneously |
|                          | 8   | ADCR_MUTE      | 0         | Right ADC Digital Mute                                                                          |
|                          |     |                |           | 0 = Disable Mute                                                                                |
|                          |     |                |           | 1 = Enable Mute                                                                                 |
|                          | 7:0 | ADCR_VOL [7:0] | 1100_0000 | Right ADC Digital Volume                                                                        |
|                          |     |                | (0dB)     | 0000_0000 = mute                                                                                |
|                          |     |                |           | 0000_0001 = -71.625dB                                                                           |
|                          |     |                |           | 0000_0010 = -71.250dB                                                                           |
|                          |     |                |           |                                                                                                 |
|                          |     |                |           | 1100_0000 = 0dB                                                                                 |
|                          |     |                |           |                                                                                                 |
|                          |     |                |           | 1111_1111 = +23.625dB                                                                           |
|                          |     |                |           | (See Table 9 for volume range)                                                                  |

**Table 8 ADC Digital Volume Control** 



Production Data \_\_\_\_\_\_ **WM8946** 

|   | ADCL_VOL or<br>ADCR VOL | Volume (dB)        | ADCL_VOL or<br>ADCR VOL | Volume (dB)        | ADCL_VOL or ADCR VOL | Volume (dB)      | ADCL_VOL or ADCR_VOL | Volume (dB)      |
|---|-------------------------|--------------------|-------------------------|--------------------|----------------------|------------------|----------------------|------------------|
| ı | 0h                      | MUTE               | 40h                     | -48.000            | 80h                  | -24.000          | C0h                  | 0.000            |
|   | 1h                      | -71.625            | 41h                     | -47.625            | 81h                  | -23.625          | C1h                  | 0.375            |
|   | 2h                      | -71.250            | 42h                     | -47.250            | 82h                  | -23.250          | C2h                  | 0.750            |
|   | 3h                      | -70.875            | 43h                     | -46.875            | 83h                  | -22.875          | C3h                  | 1.125            |
|   | 4h                      | -70.500            | 44h                     | -46.500            | 84h                  | -22.500          | C4h                  | 1.500            |
|   | 5h                      | -70.125            | 45h                     | -46.125            | 85h                  | -22.125          | C5h                  | 1.875            |
|   | 6h                      | -69.750            | 46h                     | -45.750            | 86h                  | -21.750          | C6h                  | 2.250            |
|   | 7h                      | -69.375            | 47h                     | -45.375            | 87h                  | -21.375          | C7h                  | 2.625            |
|   | 8h                      | -69.000            | 48h                     | -45.000            | 88h                  | -21.000          | C8h                  | 3.000            |
|   | 9h                      | -68.625            | 49h                     | -44.625            | 89h                  | -20.625          | C9h                  | 3.375            |
|   | Ah                      | -68.250            | 4Ah                     | -44.250            | 8Ah                  | -20.250          | CAh                  | 3.750            |
|   | Bh                      | -67.875            | 4Bh                     | -43.875            | 8Bh                  | -19.875          | CBh                  | 4.125            |
|   | Ch                      | -67.500            | 4Ch                     | -43.500            | 8Ch                  | -19.500          | CCh                  | 4.500            |
|   | Dh                      | -67.125            | 4Dh                     | -43.125            | 8Dh                  | -19.125          | CDh                  | 4.875            |
|   | Eh                      | -66.750            | 4Eh                     | -42.750            | 8Eh                  | -18.750          | CEh                  | 5.250            |
|   | Fh                      | -66.375            | 4Fh                     | -42.375            | 8Fh                  | -18.375          | CFh                  | 5.625            |
|   | 10h                     | -66.000            | 50h                     | -42.000            | 90h                  | -18.000          | D0h                  | 6.000            |
|   | 11h                     | -65.625            | 51h                     | -41.625            | 91h                  | -17.625          | D1h                  | 6.375            |
|   | 12h                     | -65.250            | 52h                     | -41.250            | 92h                  | -17.250          | D2h                  | 6.750            |
|   | 13h                     | -64.875            | 53h                     | -40.875            | 93h                  | -16.875          | D3h                  | 7.125            |
|   | 14h                     | -64.500            | 54h                     | -40.500            | 94h                  | -16.500          | D4h                  | 7.500            |
|   | 15h                     | -64.125            | 55h                     | -40.125            | 95h                  | -16.125          | D5h                  | 7.875            |
|   | 16h                     | -63.750            | 56h                     | -39.750            | 96h                  | -15.750          | D6h                  | 8.250            |
|   | 17h                     | -63.375            | 57h                     | -39.375            | 97h                  | -15.375          | D7h                  | 8.625            |
|   | 18h                     | -63.000            | 58h                     | -39.000            | 98h                  | -15.000          | D8h                  | 9.000            |
|   | 19h                     | -62.625            | 59h                     | -38.625            | 99h                  | -14.625          | D9h                  | 9.375            |
|   | 1Ah                     | -62.250            | 5Ah                     | -38.250            | 9Ah                  | -14.250          | DAh                  | 9.750            |
|   | 1Bh                     | -61.875            | 5Bh                     | -37.875            | 9Bh                  | -13.875          | DBh                  | 10.125           |
|   | 1Ch                     | -61.500            | 5Ch                     | -37.500            | 9Ch                  | -13.500          | DCh                  | 10.500           |
|   | 1Dh                     | -61.125            | 5Dh                     | -37.125            | 9Dh                  | -13.125          | DDh                  | 10.875           |
|   | 1Eh                     | -60.750            | 5Eh                     | -36.750            | 9Eh                  | -12.750          | DEh                  | 11.250           |
|   | 1Fh                     | -60.375            | 5Fh                     | -36.375            | 9Fh                  | -12.375          | DFh                  | 11.625           |
|   | 20h                     | -60.000            | 60h                     | -36.000            | A0h                  | -12.000          | E0h                  | 12.000           |
|   | 21h                     | -59.625            | 61h                     | -35.625            | A1h                  | -11.625          | E1h                  | 12.375           |
|   | 22h                     | -59.250            | 62h                     | -35.250            | A2h                  | -11.250          | E2h                  | 12.750           |
|   | 23h                     | -58.875            | 63h                     | -34.875            | A3h                  | -10.875          | E3h                  | 13.125           |
|   | 24h                     | -58.500            | 64h                     | -34.500            | A4h                  | -10.500          | E4h                  | 13.500           |
|   | 25h                     | -58.125            | 65h                     | -34.125            | A5h                  | -10.125          | E5h                  | 13.875           |
|   | 26h                     | -57.750            | 66h                     | -33.750            | A6h                  | -9.750           | E6h                  | 14.250           |
|   | 27h                     | -57.375            | 67h                     | -33.375            | A7h                  | -9.375           | E7h                  | 14.625           |
|   | 28h                     | -57.000            | 68h                     | -33.000            | A8h                  | -9.000           | E8h                  | 15.000           |
|   | 29h                     | -56.625            | 69h                     | -32.625            | A9h                  | -8.625<br>9.250  | E9h                  | 15.375           |
|   | 2Ah                     | -56.250            | 6Ah                     | -32.250<br>31.975  | AAh                  | -8.250<br>7.975  | EAh<br>EBh           | 15.750<br>16.125 |
|   | 2Bh<br>2Ch              | -55.875<br>-55.500 | 6Bh<br>6Ch              | -31.875<br>-31.500 | ABh<br>ACh           | -7.875<br>-7.500 | EBh<br>ECh           | 16.125           |
|   | 2Dh                     | -55.500<br>-55.125 | 6Dh                     | -31.125            | ADh                  | -7.125           | EDh                  | 16.875           |
|   | 2Eh                     | -55.125<br>-54.750 | 6Eh                     | -31.125            | AEh                  | -7.125<br>-6.750 | EEh                  | 17.250           |
|   | 2Fh                     | -54.375            | 6Fh                     | -30.375            | AFh                  | -6.375           | EFh                  | 17.625           |
|   | 30h                     | -54.000            | 70h                     | -30.000            | B0h                  | -6.000           | F0h                  | 18.000           |
|   | 31h                     | -53.625            | 71h                     | -29.625            | B1h                  | -5.625           | F1h                  | 18.375           |
|   | 32h                     | -53.250            | 7111<br>72h             | -29.250            | B2h                  | -5.250           | F2h                  | 18.750           |
|   | 33h                     | -52.875            | 73h                     | -28.875            | B3h                  | -4.875           | F3h                  | 19.125           |
|   | 34h                     | -52.500            | 74h                     | -28.500            | B4h                  | -4.500           | F4h                  | 19.500           |
|   | 35h                     | -52.125            | 75h                     | -28.125            | B5h                  | -4.125           | F5h                  | 19.875           |
|   | 36h                     | -51.750            | 76h                     | -27.750            | B6h                  | -3.750           | F6h                  | 20.250           |
|   | 37h                     | -51.375            | 77h                     | -27.375            | B7h                  | -3.375           | F7h                  | 20.625           |
|   | 38h                     | -51.000            | 78h                     | -27.000            | B8h                  | -3.000           | F8h                  | 21.000           |
|   | 39h                     | -50.625            | 79h                     | -26.625            | B9h                  | -2.625           | F9h                  | 21.375           |
|   | 3Ah                     | -50.250            | 7Ah                     | -26.250            | BAh                  | -2.250           | FAh                  | 21.750           |
|   | 3Bh                     | -49.875            | 7Bh                     | -25.875            | BBh                  | -1.875           | FBh                  | 22.125           |
|   | 3Ch                     | -49.500            | 7Ch                     | -25.500            | BCh                  | -1.500           | FCh                  | 22.500           |
|   | 3Dh                     | -49.125            | 7Dh                     | -25.125            | BDh                  | -1.125           | FDh                  | 22.875           |
|   | 3Eh                     | -48.750            | 7Eh                     | -24.750            | BEh                  | -0.750           | FEh                  | 23.250           |
|   | 3Fh                     | -48.375            | 7Fh                     | -24.375            | BFh                  | -0.375           | FFh                  | 23.625           |

Table 9 ADC Digital Volume Range



### **ADC HIGH PASS FILTER**

A digital high-pass filter can be applied to the ADC path to remove DC offsets. This filter can also be programmed to remove low frequency noise in handheld applications (e.g. wind noise, handling noise or mechanical vibration). This filter is controlled using the ADC\_HPF and ADC\_HPF\_CUT register bits (see Table 10).

Note that the ADC HPF is NOT enabled by default but must be used if DRC\_ENA is enabled in register R29(1Dh) bit 7. The DRC will not function correctly unless this filter is enabled.

When ADC\_HPF\_CUT=00, the high pass filter is optimised for hi-fi audio modes; the filter is designed to remove DC offsets without degrading the bass response and has a cut-off frequency of 3.7Hz at fs=44.1kHz.

In the other ADC\_HPF\_CUT modes. The high pass filter is optimised for voice communication modes. It is recommended to select a cut-off frequency below 300Hz; the preferred setting may vary according to the voice communication sample rate. (e.g. ADC\_HPF\_CUT=11 at fs=8kHz or ADC\_HPF\_CUT=10 at fs=16kHz).

| REGISTER<br>ADDRESS        | BIT | LABEL             | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                                                 |
|----------------------------|-----|-------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R26 (1Ah)<br>ADC Control 2 | 2:1 | ADC_HPF_CUT [1:0] | 00      | High pass filter configuration.  00 = 1st order HPF (fc=4Hz at fs=48kHz) 01 = 2nd order HPF (fc=122Hz at fs=48kHz) 10 = 2nd order HPF (fc=153Hz at fs=48kHz) 11 = 2nd order HPF (fc=196Hz at fs=48kHz) (See Table 11 for cut-off frequencies at all supported sample rates) |
|                            | 0   | ADC_HPF           | 0       | ADC Digital High Pass Filter Enable 0 = Disabled 1 = Enabled                                                                                                                                                                                                                |

Table 10 ADC High-pass Filter Control Registers

|             | Value of ADC_HPF_CUT bits |                        |     |     |  |  |  |
|-------------|---------------------------|------------------------|-----|-----|--|--|--|
| Sample Rate | 00                        | 01                     | 10  | 11  |  |  |  |
| (kHz)       |                           | Cut-off frequency (Hz) |     |     |  |  |  |
| 8.000       | 0.7                       | 20                     | 26  | 33  |  |  |  |
| 11.025      | 0.9                       | 28                     | 36  | 45  |  |  |  |
| 16.000      | 1.3                       | 41                     | 51  | 66  |  |  |  |
| 22.050      | 1.9                       | 56                     | 71  | 90  |  |  |  |
| 24.000      | 2.0                       | 61                     | 77  | 98  |  |  |  |
| 32.000      | 2.7                       | 81                     | 102 | 131 |  |  |  |
| 44.100      | 3.7                       | 112                    | 141 | 180 |  |  |  |
| 48.000      | 4.0                       | 122                    | 153 | 196 |  |  |  |

Table 11 ADC High-pass Filter Cut-off Frequencies

Filter response plots for the ADC high-pass filter are shown in "Digital Filter Characteristics".



## **DSP CORE**

DSP Core is at the centre of the ADC / Digital Audio Interface (I2S) blocks. It provides signal routing, and also implements a number of configurable signal processing functions.

The signal processing functions are arranged in three blocks, as follows:

- Signal Enhancement 1 (SE1) Low-pass / High-pass filter, 3D-stereo enhancement, 5 notch filters, generic 'Direct-Form 1' filter.
- Signal Enhancement 2 (SE2) ReTune<sup>™</sup> processing, 5-band equalizer.
- Signal Enhancement 3 (SE3) Dynamic range control

The DSP Configuration modes and each of the Signal Enhancement blocks is described in the following sections.

### **DSP CONFIGURATION MODES**

The DSP Configuration Mode is determined using the SE\_CONFIG register field; this configures the signal paths between the Signal Enhancement blocks and the ADC / DAC / I2S interfaces. The supported DSP modes are illustrated in Figure 13.





Figure 13 DSP Configuration Modes

Record mode enables the entire set of Signal Enhancement functions in the ADC path. The direct DAC path is also active, without any Signal Enhancement functions; this allows basic audio playback and digital beep generation.

Playback mode enables the entire set of DSP functions in the DAC path. The direct ADC path is also active, without any DSP functions; this allows basic audio record functions to the host system.

| REGISTER<br>ADDRESS                 | BIT | LABEL              | DEFAULT | DESCRIPTION                                                                                    |
|-------------------------------------|-----|--------------------|---------|------------------------------------------------------------------------------------------------|
| R64 (40h)<br>SE Config<br>Selection | 3:0 | SE_CONFIG<br>[3:0] | 0000    | DSP Configuration Mode select<br>0000 = Record mode<br>0001 = Playback mode<br>0010 = Reserved |
|                                     |     |                    |         | 0011 = Reserved                                                                                |

**Table 12 DSP Configuration Mode Select** 

### LOW-PASS / HIGH-PASS FILTER (LPF/HPF)



The Low-pass / High-pass filter is part of the SE1 block. This first-order filter can be configured to be high-pass, low-pass; it can also be bypassed. The cut-off frequency is programmable; the default setting is bypass (OFF). The left and right channel parameters may be programmed individually. The left and right filters are enabled using the SE1\_LHPF\_L\_ENA and SE1\_LHPF\_R\_ENA register bits defined in Table 13. For the derivation of the other associated registers, refer to the configuration tools supplied with the WM8946 Evaluation Kit.

Example plots of the Low-pass / High-pass filter response are shown in Figure 14.



Figure 14 Low-pass / High-pass Filter Responses



### **3D SURROUND**



The 3D-stereo surround effect is part of the SE1 block. This function uses time delays and controlled cross-talk mechanisms to adjust the depth or width of the stereo audio. The 3D-stereo surround effect includes programmable high-pass or low-pass filtering to limit the 3D effect to specific frequency bands if required. The structure of the 3D surround processing is illustrated in Figure 15.



Figure 15 3D Surround Processing

The 3D surround depth is programmable; the default setting is OFF. The 3D surround processing can also be configured to create a mono mix of the Left and Right channels.

The 3D effect is enabled on the left and right channels using the SE1\_3D\_L\_ENA and SE1\_3D\_R\_ENA register bits defined in Table 13. These bits can be set independently of each other. For the derivation of the other associated registers, refer to the configuration tools supplied with the WM8946 Evaluation Kit.

### **5-NOTCH FILTER**



The 5-notch filter is part of the SE1 block. This function allows up to 5 programmable frequency bands to be attenuated. The frequency and width of each notch is configurable; the depth of the attenuation may also be adjusted. The default setting is bypass (OFF).

The notch filters may be enabled on the left and right channels using the SE1\_NOTCH\_L\_ENA and SE1\_NOTCH\_R\_ENA register bits defined in Table 13. Note that, although the 5-notch filter can be enabled on the left/right channels independently, the parameters that define the notch filters apply equally to the left and right channels, when enabled.

The notch filter coefficients are programmed in registers R72 to R91. For the derivation of these registers, refer to the configuration tools supplied with the WM8946 Evaluation Kit.

Note that the notch filters should not be configured for centre-frequencies below 120Hz. To apply filtering at low frequencies, the SE1 High Pass Filter should be used.



Typical applications for the notch filters are filtering of fixed-frequency noise or resonances; these might arise from a motor (e.g. DSC zoom lens motor) or from characteristics of the application housing. Example plots of the Notch filter response are shown in Figure 16.



Figure 16 Notch Filter Responses

#### **DF1 FILTER**



The DF1 filter is part of the SE1 block. This provides a direct-form 1 standard filter, as illustrated in Figure 17. All of the filter coefficients are programmable for the left and right channels independently. The default coefficients give a transparent filter response.



Figure 17 Direct-Form 1 Standard Filter Structure

The DF1 response is defined by the following equations:

$$y[n] = c_1 x[n] + c_2 x[n-1] + c_3 y[n-1]$$

$$H = \frac{y}{x} = \frac{c_1 + c_2 z^{-1}}{1 - c_2 z^{-1}}$$

The DF1 filters may be enabled on the left and right channels using the SE1\_DF1\_L\_ENA and SE1\_DF1\_R\_ENA register bits defined in Table 13. For the derivation of the other associated registers, refer to the configuration tools supplied with the WM8946 Evaluation Kit.

The DF1 filter can be used to implement very complex response patterns, with specific phase and gain responses at different frequencies. Typical applications of this type of filter include the application of refinements or compensations to the 3D enhancement or other user-selected filters.

## RETUNE<sup>™</sup> FILTER



The ReTune™ filter is part of the SE2 block. This is a very advanced feature that is intended to perform frequency linearization according to the particular needs of the application microphone, loudspeaker or housing. The ReTune™ algorithms can provide acoustic equalisation and selective phase (delay) control of specific frequency bands. The left and right ReTune™ filters are enabled using the SE2\_RETUNE\_L\_ENA and SE2\_RETUNE\_R\_ENA register bits defined in Table 14.

For the derivation of the other ReTune™ configuration parameters, the Wolfson WISCE™ software must be used to analyse the requirements of the application. (Refer to WISCE for further information.) If desired, one or more sets of register coefficients might be derived for different operating scenarios, and these may be recalled and written to the CODEC registers as required in the target application. The ReTune™ configuration procedure involves the generation and analysis of test signals as outlined below.



To determine the characteristics of the microphone in an application, a test signal is applied to a loudspeaker that is in the acoustic path to the microphone. The received signal through the application microphone is analysed and compared with the received signal from a reference microphone in order to determine the characteristics of the application microphone.

To determine the characteristics of the loudspeaker in an application, a test signal is applied to the target application. A reference microphone is positioned in the normal acoustic path of the loudspeaker, and the received signal is analysed to determine how accurately the loudspeaker has reproduced the test signal.

#### 5-BAND EQ



The 5-band EQ is part of the SE2 block. This function allows 5 frequency bands to be controlled. The upper and lower frequency bands are controlled by low-pass and high-pass filters respectively. The middle three frequency bands are notch filters. The cut-off / centre frequency of each filter is programmable, and up to 12dB gain or attenuation can be selected in each case. The left and right channel parameters may be programmed individually. The 5-band EQ may be enabled using the SE2\_5BEQ\_L\_ENA register bit defined in Table 14. For the derivation of the other associated registers, refer to the WISCE software.

Note that when the right channel 5BEQ filter is disabled the gains for each of the frequency bands must be set to 0dB.

Typical applications of the 5-band EQ include the selection of user-preferences for different music types, such as 'rock', 'dance' or 'classical' EQ profiles.

## **DYNAMIC RANGE CONTROL (DRC)**



The Dynamic Range Control (DRC) forms the SE3 block. The DRC provides a range of compression, limiting and noise gate functions to support optimum configuration for recording or playback modes. The DRC is configured using the control fields in registers R29 to R35 - see "Dynamic Range Control".

## SIGNAL ENHANCEMENT REGISTER CONTROLS

The SE1 'enable' bits are described in Table 13. Note that other control fields must also be determined and written to the WM8946 using WISCE™ or other tools. The registers described below only allow the sub-blocks of SE1 to be enabled or disabled.

Note that it is not recommended to access these control fields unless appropriate values have been written to the associated bits in registers R65 to R98.



| REGISTER<br>ADDRESS            | BIT | LABEL               | DEFAULT | DESCRIPTION                                                              |
|--------------------------------|-----|---------------------|---------|--------------------------------------------------------------------------|
| R65 (41h)<br>SE1_LHPF_C        | 1   | SE1_LHPF_R_E<br>NA  | 0       | SE1 Right channel low-pass / high-<br>pass filter enable                 |
| ONFIG                          |     |                     |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |
|                                | 0   | SE1_LHPF_L_E<br>NA  | 0       | SE1 Left channel low-pass / high-<br>pass filter enable                  |
|                                |     |                     |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |
| R68 (44h)<br>SE1_3D_CON<br>FIG | 1   | SE1_3D_R_ENA        | 0       | SE1 Right channel 3D stereo<br>enhancement filter enable<br>0 = Disabled |
| FIG                            |     |                     |         | 1 = Enabled                                                              |
|                                | 0   | SE1_3D_L_ENA        | 0       | SE1 Left channel 3D stereo enhancement filter enable                     |
|                                |     |                     |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |
| R71 (47h)<br>SE1 NOTCH         | 1   | SE1_NOTCH_R<br>_ENA | 0       | SE1 Right channel notch filters enable                                   |
| CONFIG                         |     |                     |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |
|                                | 0   | SE1_NOTCH_L_<br>ENA | 0       | SE1 Left channel notch filters enable                                    |
|                                |     |                     |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |
| R92 (5Ch)                      | 1   | SE1_DF1_R_EN        | 0       | SE1 Right channel DF1 filter enable                                      |
| SE1_DF1_CO                     |     | Α                   |         | 0 = Disabled                                                             |
| NFIG                           |     |                     |         | 1 = Enabled                                                              |
|                                | 0   | SE1_DF1_L_EN        | 0       | SE1 Left channel DF1 filter enable                                       |
|                                |     | Α                   |         | 0 = Disabled                                                             |
|                                |     |                     |         | 1 = Enabled                                                              |

Table 13 Signal Enhancement Block 1 (SE1)

The SE2 'enable' bits are described in Table 14. Note that (with the exception of the SE2 HPF) other control fields must also be determined and written to the WM8946 using WISCE™ or other tools. The registers described below only allow the sub-blocks of SE2 to be enabled or disabled.

Note that it is not recommended to access these control fields unless appropriate values have been written to the associated bits in registers R99 to R175.

| REGISTER<br>ADDRESS                 | BIT | LABEL                | DEFAULT | DESCRIPTION                                                      |
|-------------------------------------|-----|----------------------|---------|------------------------------------------------------------------|
| R100 (64h)<br>SE2_RETUNE<br>_CONFIG | 1   | SE2_RETUNE_<br>R_ENA | 0       | SE2 Right channel ReTune™ filter enable 0 = Disabled 1 = Enabled |
|                                     | 0   | SE2_RETUNE_<br>L_ENA | 0       | SE2 Left channel ReTune™ filter enable 0 = Disabled 1 = Enabled  |
|                                     |     |                      |         |                                                                  |
| R133 (85h)<br>SE2_5BEQ_C<br>ONFIG   | 0   | SE2_5BEQ_L_E<br>NA   | 0       | SE2 Left channel 5-band EQ enable<br>0 = Disabled<br>1 = Enabled |

Table 14 Signal Enhancement Block 2 (SE2)

The register controls for Signal Enhancement Block SE3 are defined in the "Dynamic Range Control (DRC)" section.



WM8946 Production Data

## **DYNAMIC RANGE CONTROL (DRC)**

The dynamic range controller (DRC) is a circuit which can be enabled in the digital playback or digital record path of the WM8946, depending upon the selected DSP mode. The function of the DRC is to adjust the signal gain in conditions where the input amplitude is unknown or varies over a wide range, e.g. when recording from microphones built into a handheld system.

The DRC can apply Compression and Automatic Level Control to the signal path. It incorporates 'anticlip' and 'quick release' features for handling transients in order to improve intelligibility in the presence of loud impulsive noises.

The DRC also incorporates a Noise Gate function, which provides additional attenuation of very low-level input signals. This means that the signal path is quiet when no signal is present, giving an improvement in background noise level under these conditions.

The DRC is enabled as described in Table 15. The audio signal path controlled by the DRC depends upon the selected DSP Configuration mode - see "DSP Core" for details.

To remove any dc offsets from the input signal the ADC high pass filter must be enabled. The DRC will not function correctly unless this filter is enabled.

Note that the ADC HPF bit in register R26(1Ah) bit 0 is NOT enabled by default but MUST be used if DRC\_ENA is enabled in register R29(1Dh) bit 7.

| REGISTER<br>ADDRESS | BIT | LABEL   | DEFAULT | DESCRIPTION  |
|---------------------|-----|---------|---------|--------------|
| R29 (1Dh)           | 7   | DRC_ENA | 0       | DRC Enable   |
| DRC Control 1       |     |         |         | 0 = Disabled |
|                     |     |         |         | 1 = Enabled  |

Table 15 DRC Enable

#### DRC COMPRESSION / EXPANSION / LIMITING

The DRC supports two different compression regions, separated by a "Knee" (shown as "Knee1" in Figure 18) at a specific input amplitude. In the region above the knee, the compression slope DRC\_HI\_COMP applies; in the region below the knee, the compression slope DRC\_LO\_COMP applies.

The DRC also supports a noise gate region, where low-level input signals are heavily attenuated. This function can be enabled or disabled according to the application requirements. The DRC response in this region is defined by the expansion slope DRC\_NG\_EXP.

For additional attenuation of signals in the noise gate region, an additional "knee" can be defined (shown as "Knee2" in Figure 18). When this knee is enabled, this introduces an infinitely steep dropoff in the DRC response pattern between the DRC\_LO\_COMP and DRC\_NG\_EXP regions.

The overall DRC compression characteristic in "steady state" (i.e. where the input amplitude is near-constant) is illustrated in Figure 18.



Figure 18 DRC Response Characteristic



The slope of the DRC response is determined by register fields DRC\_HI\_COMP and DRC\_LO\_COMP. A slope of 1 indicates constant gain in this region. A slope less than 1 represents compression (i.e. a change in input amplitude produces only a smaller change in output amplitude). A slope of 0 indicates that the target output amplitude is the same across a range of input amplitudes; this is infinite compression.

When the noise gate is enabled, the DRC response in this region is determined by the DRC\_NG\_EXP register. A slope of 1 indicates constant gain in this region. A slope greater than 1 represents expansion (i.e. a change in input amplitude produces a larger change in output amplitude).

When the DRC\_KNEE2\_OP knee is enabled ("Knee2" in Figure 18), this introduces the vertical line in the response pattern illustrated, resulting in infinitely steep attenuation at this point in the response.

| REF | PARAMETER    | DESCRIPTION                   |  |  |  |
|-----|--------------|-------------------------------|--|--|--|
| 1   | DRC_KNEE_IP  | Input level at Knee1 (dB)     |  |  |  |
| 2   | DRC_KNEE_OP  | Output level at Knee1 (dB)    |  |  |  |
| 3   | DRC_HI_COMP  | Compression ratio above Knee1 |  |  |  |
| 4   | DRC_LO_COMP  | Compression ratio below Knee1 |  |  |  |
| 5   | DRC_KNEE2_IP | Input level at Knee2 (dB)     |  |  |  |
| 6   | DRC_NG_EXP   | Expansion ratio below Knee2   |  |  |  |
| 7   | DRC_KNEE2_OP | Output level at Knee2 (dB)    |  |  |  |

**Table 16 DRC Response Parameters** 

The noise gate is enabled when the DRC\_NG\_ENA register is set. When the noise gate is not enabled, parameters 5, 6, 7 above are ignored, and the DRC\_LO\_COMP slope applies to all input signal levels below Knee1.

The DRC\_KNEE2\_OP knee is enabled when the DRC\_KNEE2\_OP\_ENA register is set. When this bit is not set, then parameter 7 above is ignored, and the Knee2 position always coincides with the low end of the DRC\_LO\_COMP region.

The "Knee1" point in Figure 18 is determined by register fields DRC\_KNEE\_IP and DRC\_KNEE\_OP.

Parameter Y0, the output level for a 0dB input, is not specified directly, but can be calculated from the other parameters, using the equation:

Y0 = DRC KNEE OP - (DRC KNEE IP \* DRC HI COMP)

The DRC Compression / Expansion / Limiting parameters are defined in Table 17.

| REGISTER<br>ADDRESS        | BIT  | LABEL        | DEFAULT | DESCRIPTION                                                                                                                                                                                  |
|----------------------------|------|--------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R29 (1Dh)<br>DRC Control 1 | 8    | DRC_NG_ENA   | 0       | DRC Noise Gate Enable 0 = Disabled 1 = Enabled                                                                                                                                               |
| R32 (20h) DRC Control 4    | 12:8 | DRC_KNEE2_IP | 000000  | Input signal level at the Noise Gate threshold 'Knee2'.  00000 = -36dB  00001 = -37.5dB  00010 = -39dB  (-1.5dB steps)  11110 = -81dB  11111 = -82.5dB  Only applicable when DRC NG ENA = 1. |



| REGISTER<br>ADDRESS | BIT  | LABEL               | DEFAULT | DESCRIPTION                                   |
|---------------------|------|---------------------|---------|-----------------------------------------------|
| ADDRESS             | 7:2  | DRC_KNEE_IP         | 000000  | Input signal level at the Compressor 'Knee1'. |
|                     |      |                     |         | 000000 = 0dB                                  |
|                     |      |                     |         | 000001 = -0.75dB                              |
|                     |      |                     |         | 000010 = -1.5dB                               |
|                     |      |                     |         | (-0.75dB steps)                               |
|                     |      |                     |         | 111100 = -45dB                                |
|                     |      |                     |         | 111101 = Reserved                             |
| D00 (04b)           | 40   | DDO WHEEL OR        |         | 11111X = Reserved                             |
| R33 (21h)           | 13   | DRC_KNEE2_OP<br>ENA | 0       | DRC_KNEE2_OP Enable                           |
| DRC Control 5       |      |                     |         | 0 = Disabled<br>1 = Enabled                   |
|                     | 12:8 | DRC_KNEE2_OP        | 00000   | Output signal at the Noise Gate               |
|                     | 12.0 | DIO_INILEZ_OF       | 00000   | threshold 'Knee2'.                            |
|                     |      |                     |         | 00000 = -30dB                                 |
|                     |      |                     |         | 00001 = -31.5dB                               |
|                     |      |                     |         | 00010 = -33dB                                 |
|                     |      |                     |         | (-1.5dB steps)                                |
|                     |      |                     |         | 11110 = -75dB                                 |
|                     |      |                     |         | 11111 = -76.5dB                               |
|                     |      |                     |         | Only applicable when DRC_KNEE2_OP_ENA = 1.    |
|                     | 7:3  | DRC_KNEE_OP         | 00000   | Output signal at the Compressor               |
|                     |      |                     |         | 'Knee1'.                                      |
|                     |      |                     |         | 00000 = 0dB                                   |
|                     |      |                     |         | 00001 = -0.75dB<br>00010 = -1.5dB             |
|                     |      |                     |         | (-0.75dB steps)                               |
|                     |      |                     |         | 11110 = -22.5dB                               |
|                     |      |                     |         | 11111 = Reserved                              |
|                     | 2:0  | DRC_HI_COMP         | 011     | Compressor slope (upper region)               |
|                     |      |                     |         | 000 = 1 (no compression)                      |
|                     |      |                     |         | 001 = 1/2                                     |
|                     |      |                     |         | 010 = 1/4                                     |
|                     |      |                     |         | 011 = 1/8                                     |
|                     |      |                     |         | 100 = 1/16                                    |
|                     |      |                     |         | 101 = 0<br>110 = Reserved                     |
|                     |      |                     |         | 111 = Reserved                                |
| R35 (23h)           | 9:8  | DRC_NG_EXP          | 00      | Noise Gate slope                              |
| DRC Control 7       |      |                     |         | 00 = 1 (no expansion)                         |
|                     |      |                     |         | 01 = 2                                        |
|                     |      |                     |         | 10 = 4                                        |
|                     |      |                     |         | 11 = 8                                        |
|                     | 7:5  | DRC_LO_COMP         | 000     | Compressor slope (lower region)               |
|                     |      |                     |         | 000 = 1 (no compression)                      |
|                     |      |                     |         | 001 = 1/2<br>010 = 1/4                        |
|                     |      |                     |         | 010 = 1/4                                     |
|                     |      |                     |         | 100 = 0                                       |
|                     |      |                     |         | 101 = Reserved                                |
|                     |      |                     |         | 11X = Reserved                                |
| Table 17 DPC Co     |      |                     |         |                                               |

Table 17 DRC Control Registers



## **GAIN LIMITS**

The minimum and maximum gain applied by the DRC is set by register fields DRC\_MINGAIN, DRC\_MAXGAIN and DRC\_NG\_MINGAIN. These limits can be used to alter the DRC response from that illustrated in Figure 18. If the range between maximum and minimum gain is reduced, then the extent of the dynamic range control is reduced.

The minimum gain in the Compression regions of the DRC response is set by DRC\_MINGAIN. The minimum gain in the Noise Gate region is set by DRC\_NG\_MINGAIN. The minimum gain limit prevents excessive attenuation of the signal path.

The maximum gain limit set by DRC\_MAXGAIN prevents quiet signals (or silence) from being excessively amplified.

| REGISTER<br>ADDRESS        | BIT  | LABEL                    | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                            |
|----------------------------|------|--------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R30 (1Eh)<br>DRC Control 2 | 12:9 | DRC_NG_MING<br>AIN [3:0] | 0110    | Minimum gain the DRC can use to attenuate audio signals when the noise gate is active.  0000 = -36dB 0001 = -30dB 0010 = -24dB 0011 = -18dB 0100 = -12dB 0101 = -6dB 0110 = 0dB 0111 = 6dB 1000 = 12dB 1001 = 18dB 1001 = 18dB 1010 = 36dB 1101 = 36dB |
|                            | 4:2  | DRC_MINGAIN<br>[2:0]     | 001     | Minimum gain the DRC can use to attenuate audio signals 000 = 0dB 001 = -12dB (default) 010 = -18dB 011 = -24dB 100 = -36dB 101 = Reserved 11X = Reserved                                                                                              |
|                            | 1:0  | DRC_MAXGAIN<br>[1:0]     | 01      | Maximum gain the DRC can use to boost audio signals (dB) $00 = 12dB$ $01 = 18dB$ $10 = 24dB$ $11 = 36dB$                                                                                                                                               |

Table 18 DRC Gain Limits

#### **GAIN READBACK**

The gain applied by the DRC can be read from the DRC\_GAIN register. This is a 16-bit, fixed-point value, which expresses the DRC gain as a voltage multiplier.

DRC\_GAIN is coded as a fixed-point quantity, with an MSB weighting of 16. The first 7 bits represent the integer portion; the remaining bits represent the fractional portion. If desired, the value of this field may be interpreted by treating DRC\_GAIN as an integer value, and dividing the result by 512, as illustrated in the following examples:

DRC\_GAIN = 05D4 (hex) = 1380 (decimal)

Divide by 512 gives 2.914 voltage gain, or 4.645dB

DRC\_GAIN = 0100 (hex) = 256 (decimal)

Divide by 512 gives 0.5 voltage gain, or -3.01dB

The DRC\_GAIN register is defined in Table 19.

| REGISTER<br>ADDRESS     | BIT  | LABEL              | DEFAULT | DESCRIPTION                                                                                                                                                                                    |
|-------------------------|------|--------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R36 (24h)<br>DRC Status | 15:0 | DRC_GAIN<br>[15:0] |         | DRC Gain value.  This is the DRC gain, expressed as a voltage multiplier. Fixed point coding, MSB = 64.  The first 7 bits are the integer portion; the remaining bits are the fractional part. |

Table 19 DRC Gain Readback

#### **DYNAMIC CHARACTERISTICS**

The dynamic behaviour determines how quickly the DRC responds to changing signal levels. Note that the DRC responds to the peak signal amplitude over a period of time.

The DRC\_ATK determines how quickly the DRC gain decreases when the signal amplitude is high. The DRC DCY determines how quickly the DRC gain increases when the signal amplitude is low.

These register fields are described in Table 20. Note that the register defaults are suitable for general purpose microphone use.

| REGISTER<br>ADDRESS | BIT | LABEL         | DEFAULT | DESCRIPTION                                                                                                                                                                                           |
|---------------------|-----|---------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 7:4 | DRC_ATK [3:0] | 0100    | Attack rate relative to input signal (seconds/6dB)  0000 = Reserved  0001 = 181us  0010 = 363us  0011 = 726us  0100 = 1.45ms  0101 = 2.9ms  0110 = 5.8ms  0111 = 11.6ms  1000 = 23.2ms  1001 = 46.4ms |
|                     |     |               |         | 1010 = 92.8ms<br>1011 = 185.6ms<br>1100-1111 = Reserved                                                                                                                                               |



| REGISTER<br>ADDRESS | BIT | LABEL         | DEFAULT | DESCRIPTION                                                                                                                                          |
|---------------------|-----|---------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDRESS             | 3:0 | DRC_DCY [3:0] | 0010    | Decay rate relative to input signal (seconds/6dB)  0000 = 186ms  0001 = 372ms  0010 = 743ms  0011 = 1.49s  0100 = 2.97s  0101 = 5.94s  0110 = 11.89s |
|                     |     |               |         | 0111 = 23.78s                                                                                                                                        |
|                     |     |               |         | 1000 = 47.56s                                                                                                                                        |
|                     |     |               |         | 1001-1111 = Reserved                                                                                                                                 |

**Table 20 DRC Time Constants** 

Under the following conditions, it is possible to predict the attack times with an input sine wave:

- Decay rate is set at least 8 times the attack rate.
- Attack time \* input frequency > 1

To estimate the attack time for 10%-90%:

• Attack Time = Register Value \* 2.24

For example, if DRC\_ATK = 1.45ms/6dB, then the attack time for 10%-90% = 1.45ms  $^{\star}$  2.24 = 3.25ms.

The decay time for 10%-90% can be estimated using the graph in Figure 19.



Figure 19 Decay Time for 10%-90% vs Register Value Decay Rate

WM8946 Production Data

The decay rate register value read from the horizontal axis and the decay time for 10%-90% read from the vertical axis.

For example, if DRC DRC\_DCY = 743ms/6dB, then the estimate decay time for 10%-90% taken from the graph is 1.0s.

## **ANTI-CLIP CONTROL**

The DRC includes an Anti-Clip feature to avoid signal clipping when the input amplitude rises very quickly. This feature uses a feed-forward technique for early detection of a rising signal level. Signal clipping is avoided by dynamically increasing the gain attack rate when required. The Anti-Clip feature is enabled using the DRC\_ANTICLIP bit.

Note that the feed-forward processing increases the latency in the input signal path. The DRC Anti-Clip control is described in Table 21.

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT | DESCRIPTION          |
|---------------------|-----|--------------|---------|----------------------|
| R29 (1Dh)           | 1   | DRC_ANTICLIP | 1       | DRC Anti-clip Enable |
| DRC Control 1       |     |              |         | 0 = Disabled         |
|                     |     |              |         | 1 = Enabled          |

Table 21 DRC Anti-Clip Control

Note that the Anti-Clip feature operates entirely in the digital domain. It cannot be used to prevent signal clipping in the analogue domain nor in the source signal. Analogue clipping can only be prevented by reducing the analogue signal gain or by adjusting the source signal.

Note: The Anti-Clip and Quick Release features should not be used at the same time.

#### QUICK-RELEASE CONTROL

The DRC includes a Quick-Release feature to handle short transient peaks that are not related to the intended source signal. For example, in handheld microphone recording, transient signal peaks sometimes occur due to user handling, key presses or accidental tapping against the microphone. The Quick Release feature ensures that these transients do not cause the intended signal to be masked by the longer time constants of DRC\_DCY.

The Quick-Release feature is enabled by setting the DRC\_QR bit. When this bit is enabled, the DRC measures the crest factor (peak to RMS ratio) of the input signal. A high crest factor is indicative of a transient peak that may not be related to the intended source signal. If the crest factor exceeds the level set by DRC\_QR\_THR, then the normal decay rate (DRC\_DCY) is ignored and a faster decay rate (DRC\_QR\_DCY) is used instead.

The DRC Quick-Release control bits are described in Table 22.

| REGISTER<br>ADDRESS | BIT | LABEL               | DEFAULT | DESCRIPTION                                |
|---------------------|-----|---------------------|---------|--------------------------------------------|
| R29 (1Dh)           | 2   | DRC_QR              | 1       | DRC Quick-release Enable                   |
| DRC Control 1       |     |                     |         | 0 = Disabled                               |
|                     |     |                     |         | 1 = Enabled                                |
| R34 (22h)           | 3:2 | DRC_QR_THR          | 00      | DRC Quick-release threshold (crest         |
| DRC Control 6       |     | [1:0]               |         | factor in dB)                              |
|                     |     |                     |         | 00 = 12dB                                  |
|                     |     |                     |         | 01 = 18dB                                  |
|                     |     |                     |         | 10 = 24dB                                  |
|                     |     |                     |         | 11 = 30dB                                  |
|                     | 1:0 | DRC_QR_DCY<br>[1:0] | 00      | DRC Quick-release decay rate (seconds/6dB) |
|                     |     |                     |         | 00 = 0.725ms                               |
|                     |     |                     |         | 01 = 1.45ms                                |
|                     |     |                     |         | 10 = 5.8ms                                 |
|                     |     |                     |         | 11 = reserved                              |

Table 22 DRC Quick-Release Control

Note: The Anti-Clip and Quick Release features should not be used at the same time.



#### **DRC INITIAL VALUE**

The DRC can be set up to a defined initial condition based on the expected signal level when the DRC is enabled. This can be set using the DRC\_INIT bits in register R35 (23h) bits 4 to 0.

Note: This does NOT set the initial gain of the DRC. It sets the expected signal level of the DRC input signal when the DRC is enabled.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                  |
|---------------------|-----|----------|---------|------------------------------|
| R35 (23h)           | 4:0 | DRC_INIT | 00000   | Initial value at DRC startup |
| DRC Control 7       |     |          |         | 00000 = 0dB                  |
|                     |     |          |         | 00001 = -3.75dB              |
|                     |     |          |         | (-3.75dB steps)              |
|                     |     |          |         | 11111 = -116.25dB            |

Table 23 DRC Initial Value

# **DIGITAL-TO-ANALOGUE CONVERTER (DAC)**

The WM8946 DACs receive digital input data from the digital audio interface. (Note that, depending on the DSP Configuration mode, the digital input may first be processed and filtered in the DSP Core.) The digital audio data is converted to oversampled bit-streams in the on-chip, true 24-bit digital interpolation filters. The bit-stream data enters two multi-bit, sigma-delta DACs, which convert them to high quality analogue audio signals.

The analogue outputs from the DACs can then be mixed with other analogue inputs before being sent to the analogue output pins (see "Output Signal Path").

The DACs are enabled by the DACL\_ENA and DACR\_ENA register bits.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                          |
|---------------------|-----|----------|---------|------------------------------------------------------------------------------------------------------|
| R3 (03h)            | 1   | DACR_ENA | 0       | Right DAC Enable                                                                                     |
| Power               |     |          |         | 0 = Disabled                                                                                         |
| Management          |     |          |         | 1 = Enabled                                                                                          |
| 2                   |     |          |         | DACR_ENA must be set to 1 when processing right channel data from the DAC or Digital Beep Generator. |
|                     | 0   | DACL_ENA | 0       | Left DAC Enable                                                                                      |
|                     |     |          |         | 0 = Disabled                                                                                         |
|                     |     |          |         | 1 = Enabled                                                                                          |
|                     |     |          |         | DACR_ENA must be set to 1 when processing left channel data from the DAC or Digital Beep Generator.  |

Table 24 DAC Enable Control

Note: If the WM8946 is to be used in mono mode for playback then the left and right DACs must both be enabled.

#### DAC DIGITAL VOLUME CONTROL

The output of the DACs can be digitally amplified or attenuated over a range from -71.625dB to +23.625dB in 0.375dB steps. The volume of each channel can be controlled separately using DACL\_VOL or DACR\_VOL. The DAC Volume is part of the DAC Digital Filters block. The gain for a given eight-bit code X is given by:

 $0.375 \times (X-192) \text{ dB for } 1 \le X \le 255;$  MUTE for X = 0

The DAC\_VU bit controls the loading of digital volume control data. When DAC\_VU is set to 0, the DACL\_VOL or DACR\_VOL control data is loaded into the respective control register, but does not actually change the digital gain setting. Both left and right gain settings are updated when a 1 is written to DAC\_VU. This makes it possible to update the gain of both channels simultaneously.



Note that SYSCLK must be enabled when writing to the DAC\_VU bits. (See "Clocking and Sample Rates" for details of SYSCLK.)

The output of the DACs can be digitally muted using the DACL\_MUTE or DACR\_MUTE bits. Both DACs are muted simultaneously when the DAC\_MUTEALL bit is set.

A digital soft-mute feature is provided in order to avoid sudden glitches in the analogue signal. When DAC\_VOL\_RAMP is enabled, then all mute, un-mute or volume change commands are implemented as a gradual volume change in the digital domain. The rate at which the volume ramps up is half of the sample freq (fs/2). The DAC\_VOL\_RAMP register field is described in Table 25.

| REGISTER<br>ADDRESS                   | BIT | LABEL          | DEFAULT            | DESCRIPTION                                                                                                                                                        |
|---------------------------------------|-----|----------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R21 (15h)<br>DAC Control 1            | 8   | DAC_MUTEALL    | 1                  | DAC Digital Mute for All Channels: 0 = Disable Mute 1 = Enable Mute on all channels                                                                                |
| R22 (16h)<br>DAC Control 2            | 4   | DAC_VOL_RAMP   | 1                  | DAC Volume Ramp control 0 = Disabled 1 = Enabled                                                                                                                   |
| R23 (17h)<br>Left DAC<br>Digital Vol  | 12  | DAC_VU         | 0                  | DAC Volume Update Writing a 1 to this bit will cause Left and Right DAC volume to be updated simultaneously                                                        |
|                                       | 8   | DACL_MUTE      | 0                  | Left DAC Digital Mute 0 = Disable Mute 1 = Enable Mute                                                                                                             |
|                                       | 7:0 | DACL_VOL [7:0] | 1100_0000<br>(0dB) | Left DAC Digital Volume  0000_0000 = mute  0000_0001 = -71.625dB  0000_0010 = -71.250dB   1100_0000 = 0dB   1111_1111 = +23.625dB  (See Table 26 for volume range) |
| R24 (18h)<br>Right DAC<br>Digital Vol | 12  | DAC_VU         | 0                  | DAC Volume Update Writing a 1 to this bit will cause Left and Right DAC volume to be updated simultaneously                                                        |
|                                       | 8   | DACR_MUTE      | 0                  | Right DAC Digital Mute 0 = Disable Mute 1 = Enable Mute                                                                                                            |
|                                       | 7:0 | DACR_VOL [7:0] | 1100_0000<br>(0dB) | Right DAC volume control 0000_0000 = mute 0000_0001 = -71.625dB 0000_0010 = -71.250dB 1100_0000 = 0dB 1111_1111 = +23.625dB (See Table 26 for volume range)        |

**Table 25 DAC Digital Volume Control** 



| DACL_VOL or DACR VOL | Volume (dB)        | DACL_VOL or DACR_VOL | Volume (dB)        | DACL_VOL or DACR_VOL | Volume (dB)        | DACL_VOL or DACR VOL | Volume (dB)      |
|----------------------|--------------------|----------------------|--------------------|----------------------|--------------------|----------------------|------------------|
| 0h                   | MUTE               | 40h                  | -48.000            | 80h                  | -24.000            | C0h                  | 0.000            |
| 1h                   | -71.625            | 41h                  | -47.625            | 81h                  | -23.625            | C1h                  | 0.375            |
| 2h                   | -71.250            | 42h                  | -47.250            | 82h                  | -23.250            | C2h                  | 0.750            |
| 3h                   | -70.875            | 43h                  | -46.875            | 83h                  | -22.875            | C3h                  | 1.125            |
| 4h                   | -70.500            | 44h                  | -46.500            | 84h                  | -22.500            | C4h                  | 1.500            |
| 5h                   | -70.125            | 45h                  | -46.125            | 85h                  | -22.125            | C5h                  | 1.875            |
| 6h                   | -69.750            | 46h                  | -45.750            | 86h                  | -21.750            | C6h                  | 2.250            |
| 7h                   | -69.375            | 47h                  | -45.375            | 87h                  | -21.375            | C7h                  | 2.625            |
| 8h                   | -69.000            | 48h                  | -45.000            | 88h                  | -21.000            | C8h                  | 3.000            |
| 9h                   | -68.625            | 49h                  | -44.625            | 89h                  | -20.625            | C9h                  | 3.375            |
| Ah                   | -68.250            | 4Ah                  | -44.250            | 8Ah                  | -20.250            | CAh                  | 3.750            |
| Bh                   | -67.875            | 4Bh                  | -43.875            | 8Bh                  | -19.875            | CBh                  | 4.125            |
| Ch                   | -67.500            | 4Ch                  | -43.500            | 8Ch                  | -19.500            | CCh                  | 4.500            |
| Dh                   | -67.125            | 4Dh                  | -43.125            | 8Dh                  | -19.125            | CDh                  | 4.875            |
| Eh                   | -66.750            | 4Eh                  | -42.750            | 8Eh                  | -18.750            | CEh                  | 5.250            |
| Fh                   | -66.375            | 4Fh                  | -42.375            | 8Fh                  | -18.375            | CFh                  | 5.625            |
| 10h                  | -66.000            | 50h                  | -42.000            | 90h                  | -18.000            | D0h                  | 6.000            |
| 11h                  | -65.625            | 51h                  | -41.625            | 91h                  | -17.625            | D1h                  | 6.375            |
| 12h                  | -65.250            | 52h                  | -41.250            | 92h                  | -17.250            | D2h                  | 6.750            |
| 13h                  | -64.875            | 53h                  | -40.875            | 93h                  | -16.875            | D3h                  | 7.125            |
| 14h                  | -64.500            | 54h                  | -40.500            | 94h                  | -16.500            | D4h                  | 7.500            |
| 15h                  | -64.125            | 55h                  | -40.125            | 95h                  | -16.125            | D5h                  | 7.875            |
| 16h                  | -63.750            | 56h                  | -39.750            | 96h                  | -15.750            | D6h                  | 8.250            |
| 17h                  | -63.375            | 57h                  | -39.375            | 97h                  | -15.375            | D7h                  | 8.625            |
| 18h                  | -63.000            | 58h                  | -39.000            | 98h                  | -15.000            | D8h                  | 9.000            |
| 19h                  | -62.625            | 59h                  | -38.625            | 99h                  | -14.625            | D9h                  | 9.375            |
| 1Ah                  | -62.250            | 5Ah                  | -38.250            | 9Ah                  | -14.250            | DAh                  | 9.750            |
| 1Bh                  | -61.875            | 5Bh                  | -37.875            | 9Bh                  | -13.875            | DBh                  | 10.125           |
| 1Ch                  | -61.500            | 5Ch                  | -37.500            | 9Ch                  | -13.500            | DCh                  | 10.500           |
| 1Dh                  | -61.125            | 5Dh                  | -37.125            | 9Dh                  | -13.125            | DDh                  | 10.875           |
| 1Eh                  | -60.750            | 5Eh                  | -36.750            | 9Eh                  | -12.750            | DEh                  | 11.250           |
| 1Fh                  | -60.375            | 5Fh                  | -36.375            | 9Fh                  | -12.375            | DFh                  | 11.625           |
| 20h                  | -60.000            | 60h                  | -36.000            | A0h                  | -12.000            | E0h                  | 12.000           |
| 21h<br>22h           | -59.625            | 61h<br>62h           | -35.625            | A1h<br>A2h           | -11.625            | E1h<br>E2h           | 12.375           |
| 23h                  | -59.250            | 63h                  | -35.250            | A3h                  | -11.250            |                      | 12.750           |
| 24h                  | -58.875<br>-58.500 | 64h                  | -34.875<br>-34.500 | A4h                  | -10.875<br>-10.500 | E3h<br>E4h           | 13.125<br>13.500 |
| 25h                  | -58.125            | 65h                  | -34.125            | A5h                  | -10.125            | E5h                  | 13.875           |
| 26h                  | -57.750            | 66h                  | -33.750            | A6h                  | -9.750             | E6h                  | 14.250           |
| 27h                  | -57.375            | 67h                  | -33.375            | A7h                  | -9.750<br>-9.375   | E7h                  | 14.625           |
| 28h                  | -57.000            | 68h                  | -33.000            | A8h                  | -9.000             | E8h                  | 15.000           |
| 29h                  | -56.625            | 69h                  | -32.625            | A9h                  | -8.625             | E9h                  | 15.375           |
| 2Ah                  | -56.250            | 6Ah                  | -32.250            | AAh                  | -8.250             | EAh                  | 15.750           |
| 2Bh                  | -55.875            | 6Bh                  | -31.875            | ABh                  | -7.875             | EBh                  | 16.125           |
| 2Ch                  | -55.500            | 6Ch                  | -31.500            | ACh                  | -7.500             | ECh                  | 16.500           |
| 2Dh                  | -55.125            | 6Dh                  | -31.125            | ADh                  | -7.125             | EDh                  | 16.875           |
| 2Eh                  | -54.750            | 6Eh                  | -30.750            | AEh                  | -6.750             | EEh                  | 17.250           |
| 2Fh                  | -54.375            | 6Fh                  | -30.375            | AFh                  | -6.375             | EFh                  | 17.625           |
| 30h                  | -54.000            | 70h                  | -30.000            | B0h                  | -6.000             | F0h                  | 18.000           |
| 31h                  | -53.625            | 71h                  | -29.625            | B1h                  | -5.625             | F1h                  | 18.375           |
| 32h                  | -53.250            | 72h                  | -29.250            | B2h                  | -5.250             | F2h                  | 18.750           |
| 33h                  | -52.875            | 73h                  | -28.875            | B3h                  | -4.875             | F3h                  | 19.125           |
| 34h                  | -52.500            | 74h                  | -28.500            | B4h                  | -4.500             | F4h                  | 19.500           |
| 35h                  | -52.125            | 75h                  | -28.125            | B5h                  | -4.125             | F5h                  | 19.875           |
| 36h                  | -51.750            | 76h                  | -27.750            | B6h                  | -3.750             | F6h                  | 20.250           |
| 37h                  | -51.375            | 77h                  | -27.375            | B7h                  | -3.375             | F7h                  | 20.625           |
| 38h                  | -51.000            | 78h                  | -27.000            | B8h                  | -3.000             | F8h                  | 21.000           |
| 39h                  | -50.625            | 79h                  | -26.625            | B9h                  | -2.625             | F9h                  | 21.375           |
| 3Ah                  | -50.250            | 7Ah                  | -26.250            | BAh                  | -2.250             | FAh                  | 21.750           |
| 3Bh                  | -49.875            | 7Bh                  | -25.875            | BBh                  | -1.875             | FBh                  | 22.125           |
| 3Ch                  | -49.500            | 7Ch                  | -25.500            | BCh                  | -1.500             | FCh                  | 22.500           |
| 3Dh                  | -49.125            | 7Dh                  | -25.125            | BDh                  | -1.125             | FDh                  | 22.875           |
| 3Eh                  | -48.750            | 7Eh                  | -24.750            | BEh                  | -0.750             | FEh                  | 23.250           |
| 3Fh                  | -48.375            | 7Fh                  | -24.375            | BFh                  | -0.375             | FFh                  | 23.625           |

Table 26 DAC Digital Volume Range



## **DAC AUTO-MUTE**

The DAC digital mute and volume controls are described earlier in Table 25.

The DAC also incorporates an analogue auto-mute, which is enabled by setting DAC\_AUTOMUTE. When the auto-mute is enabled, and a series of 1024 consecutive zero-samples is detected, the DAC output is muted in order to attenuate noise that might be present in output signal path. The DAC resumes normal operation as soon as digital audio data is detected.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION           |
|---------------------|-----|-------------|---------|-----------------------|
| R21 (15h)           | 4   | DAC_AUTOMUT | 1       | DAC Auto-Mute Control |
| DAC Control 1       |     | E           |         | 0 = Disabled          |
|                     |     |             |         | 1 = Enabled           |

Table 27 DAC Auto Mute

Note: The DAC\_AUTOMUTE bit should not be set when the BEEP generator is used.

## **DAC SLOPING STOPBAND FILTER**

Two DAC filter types are available, selected by the register bit DAC\_SB\_FLT. When operating at lower sample rates (e.g. during voice communication) it is recommended that the sloping stopband filter type is selected (DAC\_SB\_FLT=1) to reduce out-of-band noise which can be audible at low DAC sample rates. See "Digital Filter Characteristics" for details of DAC filter characteristics.

| REGISTER<br>ADDRESS | BIT | LABEL      | DEFAULT | DESCRIPTION                        |
|---------------------|-----|------------|---------|------------------------------------|
| R22 (16h)           | 0   | DAC_SB_FLT | 0       | Selects DAC filter characteristics |
| DAC Control 2       |     |            |         | 0 = Normal mode                    |
|                     |     |            |         | 1 = Sloping stopband mode          |

Table 28 DAC Sloping Stopband Filter



# **DIGITAL BEEP GENERATOR**

The WM8946 provides a digital signal generator which can be used to inject an audio tone (beep) into the DAC signal path. The output of the beep generator is digitally mixed with the DAC outputs, after the DAC digital volume.

The beep is enabled using BEEP\_ENA. The beep function creates an approximation of a Sine wave. The audio frequency is set using BEEP\_RATE. The beep volume is set using BEEP\_GAIN. Note that the volume of the digital beep generator is not affected by the DAC volume or DAC mute controls.

The DAC\_AUTOMUTE bit should not be set when the BEEP generator is used.

The digital beep generator control fields are described in Table 29.

| REGISTER<br>ADDRESS | BIT | LABEL           | DEFAULT | DESCRIPTION                                                                                   |
|---------------------|-----|-----------------|---------|-----------------------------------------------------------------------------------------------|
| R37 (25h)           | 6:3 | BEEP_GAIN [3:0] | 0000    | Digital Beep Volume Control                                                                   |
| Beep Control        |     |                 |         | 0000 = mute                                                                                   |
| 1                   |     |                 |         | 0001 = -83dB                                                                                  |
|                     |     |                 |         | 0010 = -77dB                                                                                  |
|                     |     |                 |         | (6dB steps)                                                                                   |
|                     |     |                 |         | 1111 = +1dB                                                                                   |
|                     | 2:1 | BEEP_RATE [1:0] | 01      | Beep Waveform Control                                                                         |
|                     |     |                 |         | 00 = Reserved                                                                                 |
|                     |     |                 |         | 01 = 1kHz                                                                                     |
|                     |     |                 |         | 10 = 2kHz                                                                                     |
|                     |     |                 |         | 11 = 4kHz                                                                                     |
|                     | 0   | BEEP_ENA        | 0       | Digital Beep Enable                                                                           |
|                     |     |                 |         | 0 = Disabled                                                                                  |
|                     |     |                 |         | 1 = Enabled                                                                                   |
|                     |     |                 |         | Note that the DAC and associated signal path needs to be enabled when using the digital beep. |

Table 29 Digital Beep Generator

**Note:** The beep generator is clocked by the left channel DAC clock. If the beep signal is used on the right channel only, the left channel DAC must be enabled.



WM8946 Production Data

# **OUTPUT SIGNAL PATH**

The WM8946 provides two Line Output mixers and two Speaker Output mixers. Multiple inputs to each mixer provide a high degree of flexibility to route different signal paths to each of the four analogue outputs.

The DAC outputs can be routed to the mixers either directly or in inverted phase. This makes it easy to generate differential (BTL) or mono output signals.

The Auxiliary input AUX1 may be routed directly to the Speaker outputs, bypassing the Speaker PGAs and mixers. This can be used to provide a fixed-gain signal path for a "PC Beep" or similar application.

The output signal paths and associated control registers are illustrated in Figure 20.

Note that the speaker outputs are intended to drive a mono headset or speaker (in BTL configuration). They are not designed to drive stereo speakers directly.



Figure 20 Output Signal Paths



# **OUTPUT SIGNAL PATHS ENABLE**

Each analogue output pin can be independently enabled or disabled using the register bits described in Table 30. The speaker output PGAs and mixers can also be controlled.

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT | DESCRIPTION                                                  |
|---------------------|-----|--------------|---------|--------------------------------------------------------------|
| R3 (03h)            | 15  | OUTR_ENA     | 0       | LINEOUTR enable                                              |
| Power               |     |              |         | 0 = Disabled                                                 |
| management          |     |              |         | 1 = Enabled                                                  |
| 2                   | 14  | OUTL_ENA     | 0       | LINEOUTL enable                                              |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     | 13  | SPKR_PGA_ENA | 0       | Speaker Right PGA enable                                     |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     | 12  | SPKL_PGA_ENA | 0       | Speaker Left PGA enable                                      |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     | 11  | SPKR_SPKVDD_ | 0       | SPKOUTR enable                                               |
|                     |     | ENA          |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     |     |              |         | Note that SPKOUTR is also                                    |
|                     |     |              |         | controlled by SPKR_OP_ENA.                                   |
|                     |     |              |         | When powering down SPKOUTR,                                  |
|                     |     |              |         | the SPKR_SPKVDD_ENA bit should be reset first.               |
|                     | 10  | SPKL_SPKVDD_ | 0       | SPKOUTL enable                                               |
|                     | 10  | ENA          |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     |     |              |         | Note that SPKOUTL is also                                    |
|                     |     |              |         | controlled by SPKL_OP_ENA.                                   |
|                     |     |              |         | When powering down SPKOUTL,                                  |
|                     |     |              |         | the SPKL_SPKVDD_ENA bit should                               |
|                     |     |              |         | be reset first                                               |
|                     | 7   | SPKR_OP_ENA  | 0       | SPKOUTR enable                                               |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     |     |              |         | Note that SPKOUTR is also controlled by                      |
|                     |     |              |         | SPKR_SPKVDD_ENA. When                                        |
|                     |     |              |         | powering up SPKOUTR, the                                     |
|                     |     |              |         | SPKR_OP_ENA bit should be                                    |
|                     |     |              |         | enabled first.                                               |
|                     | 6   | SPKL_OP_ENA  | 0       | SPKOUTL enable                                               |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     |     |              |         | Note that SPKOUTL is also                                    |
|                     |     |              |         | controlled by SPKL_SPKVDD_ENA. When powering up SPKOUTL, the |
|                     |     |              |         | SPKL_OP_ENA bit should be                                    |
|                     |     |              |         | enabled first                                                |
|                     | 3   | SPKR_MIX_ENA | 0       | Right speaker output mixer enable                            |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |
|                     | 2   | SPKL_MIX_ENA | 0       | Left speaker output mixer enable                             |
|                     |     |              |         | 0 = Disabled                                                 |
|                     |     |              |         | 1 = Enabled                                                  |

Table 30 Output Signal Paths Enable



To enable the output PGAs and mixers, the reference voltage VMID and the bias current must also be enabled. See "Reference Voltages and Master Bias" for details of the associated controls VMID\_SEL and BIAS\_ENA.

Note that the Line outputs, Speaker outputs and Speaker PGA mixers are all muted by default. The required signal paths must be un-muted using the control bits described in the respective tables below

## LINE OUTPUT MIXER CONTROL

The Line Output mixer controls are described in Table 31 for the Left Channel (MIXOUTL) and Table 32 for the Right Channel (MIXOUTR). These allow any of the DACL/R, Inverted DACL/R, AUX1/2 and one of the ADC Bypass signals to be mixed. The output of each mixer can be muted also, using the LINEL\_MUTE and LINER\_MUTE bits.

Care should be taken when mixing more than one path to the Line Output mixers in order to avoid clipping. The gain of each input path is adjustable using a selectable -6dB control in each path to facilitate this.

Note that the attenuation control fields DACL\_TO\_OUTL\_ATTEN and DACR\_TO\_OUTL\_ATTEN control both the DAC and the Inverted DAC mixer paths to the Left Channel output mixer. The equivalent applies to DACL\_TO\_OUTR\_ATTEN and DACR\_TO\_OUTR\_ATTEN also. Note that the DAC input levels may also be controlled by the DAC digital volume control - see "Digital to Analogue Converter (DAC)" for further details.

When the AUX1 or AUX2 pin is used as an audio input, that pin must be configured for audio using the AUX1\_AUDIO or AUX2\_AUDIO register bits. These bits are defined in Table 2 (see "Analogue Input Signal Path").

| REGISTER<br>ADDRESS       | BIT | LABEL             | DEFAULT | DESCRIPTION                                                |
|---------------------------|-----|-------------------|---------|------------------------------------------------------------|
| R42 (2Ah)                 | 8   | LINEL_MUTE        | 1       | LINEOUTL Output Mute                                       |
| Output ctrl               |     |                   |         | 0 = Disable Mute                                           |
|                           |     |                   |         | 1 = Enable Mute                                            |
| R49 (31h)<br>Line L mixer | 6   | BYPL_TO_OUTL      | 0       | Left Input PGA (ADC bypass) to<br>Left Output Mixer select |
| control 1                 |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |
|                           | 5   | MDACL_TO_OUT L    | 0       | Inverted Left DAC to Left Output Mixer select              |
|                           |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |
|                           | 4   | MDACR_TO_OU<br>TL | 0       | Inverted Right DAC to Left Output Mixer select             |
|                           |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |
|                           | 3   | DACL_TO_OUTL      | 0       | Left DAC to Left Output Mixer select                       |
|                           |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |
|                           | 2   | DACR_TO_OUTL      | 0       | Right DAC to Left Output Mixer select                      |
|                           |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |
|                           | 1   | AUX2_TO_OUTL      | 0       | AUX2 Audio Input to Left Output                            |
|                           |     |                   |         | Mixer select                                               |
|                           |     |                   |         | 0 = Disabled                                               |
|                           |     |                   |         | 1 = Enabled                                                |



| REGISTER<br>ADDRESS                    | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                                                        |
|----------------------------------------|-----|------------------------|---------|----------------------------------------------------------------------------------------------------|
|                                        | 0   | AUX1_TO_OUTL           | 0       | AUX1 Audio Input to Left Output Mixer select 0 = Disabled 1 = Enabled                              |
| R51 (33h)<br>Line L mixer<br>control 2 | 6   | BYPL_TO_OUTL<br>_ATTEN | 0       | Left Input PGA (ADC bypass) to<br>Left Output Mixer attenuation<br>0 = 0dB<br>1 = -6dB attenuation |
|                                        | 3   | DACL_TO_OUTL<br>_ATTEN | 0       | Left DAC to Left Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                             |
|                                        | 2   | DACR_TO_OUTL<br>_ATTEN | 0       | Right DAC to Left Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                            |
|                                        | 1   | AUX2_TO_OUTL<br>_ATTEN | 0       | AUX2 Audio Input to Left Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                     |
|                                        | 0   | AUX1_TO_OUTL<br>_ATTEN | 0       | AUX1 Audio Input to Left Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                     |

Table 31 Left Output Mixer (MIXOUTL) Control

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT | DESCRIPTION                        |
|---------------------|-----|--------------|---------|------------------------------------|
| R42 (2Ah)           | 9   | LINER_MUTE   | 1       | LINEOUTR Output Mute               |
| Output ctrl         |     |              |         | 0 = Disable Mute                   |
|                     |     |              |         | 1 = Enable Mute                    |
| R50 (32h)           | 6   | BYPR_TO_OUTR | 0       | Right Input PGA (ADC bypass) to    |
| Line R mixer        |     |              |         | Right Output Mixer select          |
| control 1           |     |              |         | 0 = Disabled                       |
|                     |     |              |         | 1 = Enabled                        |
|                     | 5   | MDACL_TO_OUT | 0       | Inverted Left DAC to Right Output  |
|                     |     | R            |         | Mixer select                       |
|                     |     |              |         | 0 = Disabled                       |
|                     |     |              |         | 1 = Enabled                        |
|                     | 4   | MDACR_TO_OU  | 0       | Inverted Right DAC to Right Output |
|                     |     | TR           |         | Mixer select                       |
|                     |     |              |         | 0 = Disabled                       |
|                     |     |              |         | 1 = Enabled                        |
|                     | 3   | DACL_TO_OUTR | 0       | Left DAC to Right Output Mixer     |
|                     |     |              |         | select                             |
|                     |     |              |         | 0 = Disabled                       |
|                     |     |              |         | 1 = Enabled                        |
|                     | 2   | DACR_TO_OUTR | 0       | Right DAC to Right Output Mixer    |
|                     |     |              |         | select                             |
|                     |     |              |         | 0 = Disabled                       |
|                     |     |              |         | 1 = Enabled                        |

| REGISTER<br>ADDRESS                    | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                                                          |
|----------------------------------------|-----|------------------------|---------|------------------------------------------------------------------------------------------------------|
|                                        | 1   | AUX2_TO_OUTR           | 0       | AUX2 Audio Input to Right Output Mixer select 0 = Disabled 1 = Enabled                               |
|                                        | 0   | AUX1_TO_OUTR           | 0       | AUX1 Audio Input to Right Output Mixer select 0 = Disabled 1 = Enabled                               |
| R52 (34h)<br>Line R mixer<br>control 2 | 6   | BYPR_TO_OUTR<br>_ATTEN | 0       | Right Input PGA (ADC bypass) to<br>Right Output Mixer attenuation<br>0 = 0dB<br>1 = -6dB attenuation |
|                                        | 3   | DACL_TO_OUTR<br>_ATTEN | 0       | Left DAC to Right Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                              |
|                                        | 2   | DACR_TO_OUTR<br>_ATTEN | 0       | Right DAC to Right Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                             |
|                                        | 1   | AUX2_TO_OUTR<br>_ATTEN | 0       | AUX2 Audio Input to Right Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                      |
|                                        | 0   | AUX1_TO_OUTR<br>_ATTEN | 0       | AUX1 Audio Input to Right Output Mixer attenuation 0 = 0dB 1 = -6dB attenuation                      |

Table 32 Right Output Mixer (MIXOUTR) Control

## SPEAKER PGA MIXER CONTROL

The Speaker PGA mixer controls are described in Table 33 for the left channel (MIXSPKL) and Table 34 for the right channel (MIXSPKR). These allow any of the DACL/R, Inverted DACL/R, AUX1/2 and one of the ADC Bypass signals to be mixed. The output of each PGA mixer can be muted also, using the SPKL\_MIX\_MUTE and SPKR\_MIX\_MUTE bits.

Note that the output from the Speaker PGA mixer is also controlled by the Speaker PGA Volume control and the Speaker Output control described in the following sections.

Care should be taken when enabling more than one path to the Speaker PGA mixers in order to avoid clipping. The gain of each input path is adjustable using a selectable -6dB control in each path to facilitate this.

Note that the attenuation control fields DACL\_TO\_PGAL\_ATTEN and DACR\_TO\_PGAL\_ATTEN control both the DAC and the Inverted DAC mixer paths to the Left Speaker PGA mixer. The equivalent applies to DACL\_TO\_PGAR\_ATTEN and DACR\_TO\_PGAR\_ATTEN also. Note that the DAC input levels may also be controlled by the DAC digital volume control - see "Digital to Analogue Converter (DAC)" for further details.

When the AUX1 or AUX2 pin is used as an audio input, that pin must be configured for audio using the AUX1\_AUDIO or AUX2\_AUDIO register bits. These bits are defined in Table 2 (see "Analogue Input Signal Path").



| REGISTER<br>ADDRESS                 | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                                                             |
|-------------------------------------|-----|------------------------|---------|---------------------------------------------------------------------------------------------------------|
| R3 (03h)<br>Power<br>Management     | 4   | SPKL_MIX_MUT<br>E      | 1       | Left Speaker PGA Mixer Mute 0 = Disable Mute 1 = Enable Mute                                            |
| R43 (2Bh)<br>SPK mixer<br>control 1 | 6   | BYPL_TO_PGAL           | 0       | Left Input PGA (ADC bypass) to<br>Left Speaker PGA Mixer select<br>0 = Disabled<br>1 = Enabled          |
|                                     | 5   | MDACL_TO_PGA<br>L      | 0       | Inverted Left DAC to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                             |
|                                     | 4   | MDACR_TO_PG<br>AL      | 0       | Inverted Right DAC to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                            |
|                                     | 3   | DACL_TO_PGAL           | 0       | Left DAC to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                                      |
|                                     | 2   | DACR_TO_PGAL           | 0       | Right DAC to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                                     |
|                                     | 1   | AUX2_TO_PGAL           | 0       | AUX2 Audio Input to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                              |
|                                     | 0   | AUX1_TO_PGAL           | 0       | AUX1 Audio Input to Left Speaker PGA Mixer select 0 = Disabled 1 = Enabled                              |
| R45 (2Dh)<br>SPK mixer<br>control 3 | 6   | BYPL_TO_PGAL<br>_ATTEN | 0       | Left Input PGA (ADC bypass) to<br>Left Speaker PGA Mixer attenuation<br>0 = 0dB<br>1 = -6dB attenuation |
|                                     | 3   | DACL_TO_PGAL<br>_ATTEN | 0       | Left DAC to Left Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                             |
|                                     | 2   | DACR_TO_PGAL<br>_ATTEN | 0       | Right DAC to Left Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                            |
|                                     | 1   | AUX2_TO_PGAL<br>_ATTEN | 0       | AUX2 Audio Input to Left Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                     |
|                                     | 0   | AUX1_TO_PGAL<br>_ATTEN | 0       | AUX1 Audio Input to Left Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                     |

Table 33 Left Speaker PGA Mixer (MIXSPKL) Control



| REGISTER<br>ADDRESS                 | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                               |
|-------------------------------------|-----|------------------------|---------|---------------------------------------------------------------------------|
| R3 (03h)                            | 5   | SPKR_MIX_MUT           | 1       | Right Speaker PGA Mixer Mute                                              |
| Power                               |     | E                      |         | 0 = Disable Mute                                                          |
| Management<br>1                     |     |                        |         | 1 = Enable Mute                                                           |
| R44 (2Ch)<br>SPK mixer              | 6   | BYPR_TO_PGAR           | 0       | Right Input PGA (ADC bypass) to Right Speaker PGA Mixer select            |
| control 2                           |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 5   | MDACL_TO_PGA<br>R      | 0       | Inverted Left DAC to Right Speaker PGA Mixer select                       |
|                                     |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 4   | MDACR_TO_PG<br>AR      | 0       | Inverted Right DAC to Right Speaker PGA Mixer select                      |
|                                     |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 3   | DACL_TO_PGAR           | 0       | Left DAC to Right Speaker PGA<br>Mixer select                             |
|                                     |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 2   | DACR_TO_PGAR           | 0       | Right DAC to Right Speaker PGA Mixer select                               |
|                                     |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 1   | AUX2_TO_PGAR           | 0       | AUX2 Audio Input to Right Speaker PGA Mixer select                        |
|                                     |     |                        |         | 0 = Disabled                                                              |
|                                     |     |                        |         | 1 = Enabled                                                               |
|                                     | 0   | AUX1_TO_PGAR           | 0       | AUX1 Audio Input to Right Speaker PGA Mixer select                        |
|                                     |     |                        |         | 0 = Disabled<br>1 = Enabled                                               |
| R46 (2Eh)<br>SPK mixer<br>control 4 | 6   | BYPR_TO_PGAR<br>_ATTEN | 0       | Right Input PGA (ADC bypass) to<br>Right Speaker PGA Mixer<br>attenuation |
|                                     |     |                        |         | 0 = 0dB                                                                   |
|                                     |     |                        |         | 1 = -6dB attenuation                                                      |
|                                     | 3   | DACL_TO_PGAR<br>_ATTEN | 0       | Left DAC to Right Speaker PGA<br>Mixer attenuation                        |
|                                     |     |                        |         | 0 = 0dB                                                                   |
|                                     |     |                        |         | 1 = -6dB attenuation                                                      |
|                                     | 2   | DACR_TO_PGAR<br>_ATTEN | 0       | Right DAC to Right Speaker PGA Mixer attenuation                          |
|                                     |     |                        |         | 0 = 0dB                                                                   |
|                                     |     |                        |         | 1 = -6dB attenuation                                                      |
|                                     | 1   | AUX2_TO_PGAR<br>_ATTEN | 0       | AUX2 Audio Input to Right Speaker PGA Mixer attenuation                   |
|                                     |     |                        |         | 0 = 0dB                                                                   |
|                                     |     | ALD/4 TO 55:5          | -       | 1 = -6dB attenuation                                                      |
|                                     | 0   | AUX1_TO_PGAR<br>_ATTEN | 0       | AUX1 Audio Input to Right Speaker PGA Mixer attenuation                   |
|                                     |     |                        |         | 0 = 0dB                                                                   |
|                                     |     | <br>PGA Mixer (MIXSPKE |         | 1 = -6dB attenuation                                                      |

Table 34 Right Speaker PGA Mixer (MIXSPKR) Control



#### SPEAKER PGA VOLUME CONTROL

The volume control of the left and right Speaker PGAs can be independently adjusted using the SPKL\_VOL and SPKR\_VOL register fields as described in Table 35. The gain range is -57dB to +6dB in 1dB steps.

Note that the output from the Speaker PGA Volume control is an input to the Speaker Output control described in the following section.

To prevent "zipper noise", a zero-cross function is provided on the Speaker PGAs. When this feature is enabled, volume updates will not take place until a zero-crossing is detected. In the case of a long period without zero-crossings, a timeout function is provided. When the zero-cross function is enabled, the volume will update after the timeout period if no earlier zero-cross has occurred. The timeout clock is enabled using TOCLK\_ENA. See "Clocking and Sample Rates" for the definition of this bit.

The SPK\_VU bits control the loading of the Speaker PGA volume data. When SPK\_VU is set to 0, the volume control data will be loaded into the respective control register, but will not actually change the gain setting. The left and right Speaker PGA volume settings are both updated when a 1 is written to either SPK\_VU bit. This makes it possible to update the gain of the left and right output paths simultaneously.

Note that SYSCLK must be enabled when writing to the SPK\_VU bits. (See "Clocking and Sample Rates" for details of SYSCLK.)

The Speaker PGA volume control register fields are described in Table 35.

| REGISTER<br>ADDRESS                   | BIT | LABEL             | DEFAULT          | DESCRIPTION                                                                                                                       |
|---------------------------------------|-----|-------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| R47 (2Fh)<br>Left SPK<br>volume ctrl  | 8   | SPK_VU            | 0                | Speaker PGA Volume Update Writing a 1 to this bit will cause the Left and Right Speaker PGA volumes to be updated simultaneously. |
|                                       | 7   | SPKL_ZC           | 0                | Left Speaker PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                               |
|                                       | 6   | SPKL_PGA_MUT<br>E | 1                | Left Speaker PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                            |
|                                       | 5:0 | SPKL_VOL          | 11_1001<br>(0dB) | Left Speaker PGA Volume  00_0000 = -57dB gain  00_0001 = -56dB   11_1001 = 0dB   11_1111 = +6dB  (See Table 36 for volume range)  |
| R48 (30h)<br>Right SPK<br>volume ctrl | 8   | SPK_VU            | 0                | Speaker PGA Volume Update Writing a 1 to this bit will cause the Left and Right Speaker PGA volumes to be updated simultaneously. |
|                                       | 7   | SPKR_ZC           | 0                | Right Speaker PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                              |
|                                       | 6   | SPKR_PGA_MUT<br>E | 1                | Right Speaker PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                           |



| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                     |
|---------------------|-----|----------|---------|---------------------------------|
|                     | 5:0 | SPKR_VOL | 11_1001 | Right Speaker PGA Volume        |
|                     |     |          | (0dB)   | 00_0000 = -57dB gain            |
|                     |     |          |         | 00_0001 = -56dB                 |
|                     |     |          |         |                                 |
|                     |     |          |         | 11_1001 = 0dB                   |
|                     |     |          |         |                                 |
|                     |     |          |         | 11_1111 = +6dB                  |
|                     |     |          |         | (See Table 36 for volume range) |

Table 35 Speaker PGA Volume Control

| PGA GAIN SETTING | VOLUME (dB) | PGA GAIN SETTING | VOLUME (dB) |
|------------------|-------------|------------------|-------------|
| 00h              | -57         | 20h              | -25         |
| 01h              | -56         | 21h              | -24         |
| 02h              | -55         | 22h              | -23         |
| 03h              | -54         | 23h              | -22         |
| 04h              | -53         | 24h              | -21         |
| 05h              | -52         | 25h              | -20         |
| 06h              | -51         | 26h              | -19         |
| 07h              | -50         | 27h              | -18         |
| 08h              | -49         | 28h              | -17         |
| 09h              | -48         | 29h              | -16         |
| 0Ah              | -47         | 2Ah              | -15         |
| 0Bh              | -46         | 2Bh              | -14         |
| 0Ch              | -45         | 2Ch              | -13         |
| 0Dh              | -44         | 2Dh              | -12         |
| 0Eh              | -43         | 2Eh              | -11         |
| 0Fh              | -42         | 2Fh              | -10         |
| 10h              | -41         | 30h              | -9          |
| 11h              | -40         | 31h              | -8          |
| 12h              | -39         | 32h              | -7          |
| 13h              | -38         | 33h              | -6          |
| 14h              | -37         | 34h              | -5          |
| 15h              | -36         | 35h              | -4          |
| 16h              | -35         | 36h              | -3          |
| 17h              | -34         | 37h              | -2          |
| 18h              | -33         | 38h              | -1          |
| 19h              | -32         | 39h              | 0           |
| 1Ah              | -31         | 3Ah              | +1          |
| 1Bh              | -30         | 3Bh              | +2          |
| 1Ch              | -29         | 3Ch              | +3          |
| 1Dh              | -28         | 3Dh              | +4          |
| 1Eh              | -27         | 3Eh              | +5          |
| 1Fh              | -26         | 3Fh              | +6          |

Table 36 Speaker PGA Volume Range

#### **SPEAKER OUTPUT CONTROL**

Each Speaker output has its own output mixer. This allows the output of the respective Speaker PGA to be enabled or disabled, and also allows the Auxiliary input AUX1 to be routed directly to either Speaker output. The two Speaker outputs can be muted also, using the SPKR\_OP\_MUTE and SPKL\_OP\_MUTE.

The AUX1 path can be used to provide a fixed-gain signal path that is unaffected by the Speaker PGA setting. This feature is intended for a "PC Beep" or similar applications.

Care should be taken when enabling more than one path to the Speaker Output mixers in order to avoid clipping. The gain of each input path is adjustable using a selectable -6dB control in each path to facilitate this.

When the AUX1 pin is used as an audio input, that pin must be configured for audio using the AUX1\_AUDIO register bit. This bit is defined in Table 2 (see "Analogue Input Signal Path").

The Speaker Output control registers are described in Table 37.

| REGISTER<br>ADDRESS                 | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                                                     |
|-------------------------------------|-----|------------------------|---------|-------------------------------------------------------------------------------------------------|
| R3 (03h)<br>Power<br>Management     | 9   | SPKR_OP_MUTE           | 1       | SPKOUTR Output Mute 0 = Disable Mute 1 = Enable Mute                                            |
| 1                                   | 8   | SPKL_OP_MUTE           | 1       | SPKOUTL Output Mute 0 = Disable Mute 1 = Enable Mute                                            |
| R43 (2Bh)<br>SPK mixer<br>control 1 | 8   | AUX1_TO_SPKL           | 0       | AUX1 Audio Input to Left Speaker Output select 0 = Disabled 1 = Enabled                         |
|                                     | 7   | PGAL_TO_SPKL           | 0       | Left Speaker PGA Mixer to Left Speaker Output select 0 = Disabled 1 = Enabled                   |
| R44 (2Ch)<br>SPK mixer<br>control 2 | 8   | AUX1_TO_SPKR           | 0       | AUX1 Audio Input to Right Speaker Output select 0 = Disabled 1 = Enabled                        |
|                                     | 7   | PGAR_TO_SPKR           | 0       | Right Speaker PGA Mixer to Right Speaker Output select 0 = Disabled 1 = Enabled                 |
| R45 (2Dh)<br>SPK mixer<br>control 3 | 8   | AUX1_TO_SPKL_<br>ATTEN | 0       | AUX1 Audio Input to Left Speaker Output attenuation 0 = 0dB 1 = -6dB attenuation                |
|                                     | 7   | PGAL_TO_SPKL<br>_ATTEN | 0       | Left Speaker PGA Mixer to Left<br>Speaker Output attenuation<br>0 = 0dB<br>1 = -6dB attenuation |
| R46 (2Eh)<br>SPK mixer<br>control 4 | 8   | AUX1_TO_SPKR<br>_ATTEN | 0       | AUX1 Audio Input to Right Speaker Output attenuation 0 = 0dB 1 = -6dB attenuation               |
|                                     | 7   | PGAR_TO_SPKR<br>_ATTEN | 0       | Right Speaker PGA Mixer to Right Speaker Output attenuation 0 = 0dB 1 = -6dB attenuation        |

**Table 37 Speaker Output Control** 



WM8946 Production Data

## ANALOGUE OUTPUTS

The Line outputs and Speaker outputs are highly configurable and may be used in many different ways. The output mixers can be configured to generate mono or stereo, single-ended or differential outputs. The Class AB Speaker output driver can deliver up to 400mW into an  $8\Omega$  speaker in BTL mode. Alternatively, the Speaker outputs can deliver 40mW to a stereo  $16\Omega$  headphone load.

#### **LINE OUTPUTS**

The line outputs LINEOUTL and LINEOUTR are the external connections to the Line output mixers. In a typical application, these will deliver a stereo pair of outputs in single-ended configuration.

For stereo line output, the Left and Right output mixers are used to generate the Left and Right output signals respectively.

A differential mono (left+right) DAC output may be generated at the line outputs by routing an inverted DAC signal to one output and the non-inverted signal from the other DAC to the other line output.

A differential output from a single DAC may be generated at the line outputs by routing the inverted DAC signal to one output and the non-inverted DAC signal to the other. When the speaker outputs are similarly configured for the other DAC channel, then stereo differential output is possible.

#### **SPEAKER OUTPUTS**

The speaker outputs SPKOUTL and SPKOUTR are the external connections to the Speaker Output mixers. These outputs are intended for a mono speaker or headphone in BTL configuration or for a stereo line load.

For stereo line configuration, the Left and Right Speaker Output mixers are used to generate the Left and Right output signals respectively.

For mono speaker or headphone configuration, a BTL output from the DACs may be generated by routing an inverted DAC signal to one speaker output and the non-inverted signal from the other DAC to the other speaker output. The auxiliary inputs AUX1 or AUX2 may be routed to the mono speaker by enabling the respective signal path in either the Left or Right speaker output mixer. (Note that these signals should not be enabled in both mixers at once; this will lead to cancellation at the BTL output.)

Note that a differential output from a single DAC may be generated at the speaker outputs by routing the inverted DAC signal to one output and the non-inverted DAC signal to the other. When the line outputs are similarly configured for the other DAC channel, then stereo differential output is possible.

#### **EXTERNAL COMPONENTS FOR LINE OUTPUT**

In single-ended output configurations, DC blocking capacitors are required at the output pins (LINEOUTL, LINEOUTR, SPKOUTL and SPKOUTR). See "Applications Information" for details of these components.



# **LDO REGULATOR**

The WM8946 provides an internal LDO which provides a regulated voltage for use as in internal supply and reference, which can also be used to power external circuits.

The LDO is enabled by setting the LDO\_ENA register bit. The LDO supply is drawn from the LDOVDD pin; the LDO output is provided on the LDOVOUT pin. The LDO requires a reference voltage and a bias source; these are configured as described below.

The LDO bias source is selected using LDO\_BIAS\_SRC. Care is required during start-up to ensure that the selected bias is enabled; the master bias will not normally be available at initial start-up, and the fast bias should be selected in the first instance.

The LDO reference voltage can be selected using LDO\_REF\_SEL; this allows selection of either the internal bandgap reference or one of the VMID resistor strings. When VMID is selected as the reference, then LDO\_REF\_SEL\_FAST selects either the Normal VMID reference or the Fast-Start VMID reference. Care is required during start-up to ensure that the selected reference is enabled; the VMID references are enabled using VMID\_ENA and VMID\_FAST\_START as described in Table 41 and Table 42 respectively.

The internal bandgap reference is nominally 1.5V. Note that this value is not trimmed and may vary significantly (+/-10%) between different devices. When using this reference, the internal bandgap reference must be enabled by setting the BG\_ENA register, as described in Table 38. The bandgap voltage can be adjusted using the BG\_VSEL register as described in Table 40.

The LDO output voltage is set using the LDO\_VSEL register, which sets the ratio of the output voltage to the LDO reference voltage. See Table 39 for LDO output voltages.

#### Example 1:

How to generate an LDOVOUT voltage of 3.0V from a 3.3V LDOVDD supply voltage.

LDO\_REF\_SEL = 0 (VMID as the reference voltage)

VMID = 1.5V (VMID REF SEL = 0, VMID CTRL = 0)

LDOVOUT = Vref \* 1.97 = 1.5V \* 1.97 = 2.96V. (see Table 39)

## Example 2:

Generating an LDOVOUT voltage of 2.4V from a 3.0V LDOVDD supply.

For maximum signal swing the VMID voltage should be half of the LDOVOUT voltage. For LDOVOUT of 2.4V the optimum VMID voltage is 1.2V. Select the VMID source voltage as LDOVOUT (VMID\_REF\_SEL = 1) and the VMID ratio as 1/2 (VMID\_CTRL = 1). This gives VMID = 1.2V.

VMID cannot be used as the LDO reference voltage so use the Bandgap voltage as the LDO reference voltage (LDO\_REF\_SEL = 1, BG\_ENA = 1). The default Bandgap voltage is 1.467V. For LDOVOUT of 2.4V LDOVSEL should be set to 2.4V / 1.467V = 1.636. Referring to Table 39 LDO\_VSEL = 03h will give LDOVOUT =  $1.467 \times 1.66 = 2.435V$ .

Note that the Bandgap voltage is not trimmed so if required the Bandgap voltage can be changed (BG VSEL – see Table 40) to get closer to the required voltage.

By default, the LDO output is actively discharged to GND through internal resistors when the LDO is disabled. This is desirable in shut-down to prevent any external connections being affected by the internal circuits. The LDO output can be set to float when the LDO is disabled; this is selected by setting the LDO\_OP\_FLT bit. This option should be selected if the LDO is bypassed and an external voltage is applied to LDOVOUT.

The LDO output is monitored for voltage accuracy. The LDO undervoltage status can be read at any time from the LDO\_UV\_STS bit, as described in Table 38. This bit can be polled at any time, or may output directly on a GPIO pin, or may be used to generate Interrupt events.



| REGISTER<br>ADDRESS | BIT | LABEL         | DEFAULT | DESCRIPTION                                                                                                                                                                            |
|---------------------|-----|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R17 (11h)           | 0   | LDO_UV_STS    | 0       | LDO Undervoltage status                                                                                                                                                                |
| Status Flags        |     |               |         | 0 = Normal                                                                                                                                                                             |
|                     |     |               |         | 1 = Undervoltage                                                                                                                                                                       |
| R53 (35h)           | 15  | LDO_ENA       | 0       | LDO Enable                                                                                                                                                                             |
| LDO                 |     |               |         | 0 = Disabled                                                                                                                                                                           |
|                     |     |               |         | 1 = Enabled                                                                                                                                                                            |
|                     | 14  | LDO_REF_SEL_F | 0       | LDO Voltage reference select                                                                                                                                                           |
|                     |     | AST           |         | 0 = VMID (normal)                                                                                                                                                                      |
|                     |     |               |         | 1 = VMID (fast start)                                                                                                                                                                  |
|                     |     |               |         | This field is only effective when LDO_REF_SEL = 0                                                                                                                                      |
|                     | 13  | LDO_REF_SEL   | 0       | LDO Voltage reference select                                                                                                                                                           |
|                     |     |               |         | 0 = VMID                                                                                                                                                                               |
|                     |     |               |         | 1 = Bandgap                                                                                                                                                                            |
|                     | 12  | LDO_OPFLT     | 0       | LDO Output float                                                                                                                                                                       |
|                     |     |               |         | 0 = Disabled (Output discharged when disabled)                                                                                                                                         |
|                     |     |               |         | 1 = Enabled (Output floats when disabled)                                                                                                                                              |
|                     | 5   | LDO_BIAS_SRC  | 0       | LDO Bias Source select                                                                                                                                                                 |
|                     |     |               |         | 0 = Master Bias                                                                                                                                                                        |
|                     |     |               |         | 1 = Start-Up Bias                                                                                                                                                                      |
|                     | 4:0 | LDO_VSEL      | 00111   | LDO Voltage select                                                                                                                                                                     |
|                     |     |               |         | (Sets the LDO output as a ratio of<br>the selected voltage reference. The<br>voltage reference is set by<br>LDO_REF_SEL.)<br>00111 = Vref x 1.97 (default)<br>(See Table 39 for range) |
| R54 (36h)           | 15  | BG_ENA        | 0       | Bandgap Reference Control                                                                                                                                                              |
| Bandgap             |     |               |         | 0 = Disabled                                                                                                                                                                           |
|                     |     |               |         | 1 = Enabled                                                                                                                                                                            |
|                     | 4:0 | BG_VSEL[4:0]  | 01010   | Bandgap Voltage select                                                                                                                                                                 |
|                     |     |               |         | (Sets the Bandgap voltage)                                                                                                                                                             |
|                     |     |               |         | 00000 = 1.200V                                                                                                                                                                         |
|                     |     |               |         | 26.7mV steps                                                                                                                                                                           |
|                     |     |               |         | 01010 = 1.467V (default)                                                                                                                                                               |
|                     |     |               |         | 01111 = 1.600V                                                                                                                                                                         |
|                     |     |               |         | 10000 to 11111 = reserved                                                                                                                                                              |
|                     |     |               |         | (See Table 40 for values)                                                                                                                                                              |

Table 38 LDO Regulator Control



| LDO_VSEL [4:0]           | LDO OUTPUT              | LDO_VSEL [4:0]         | LDO OUTPUT  |
|--------------------------|-------------------------|------------------------|-------------|
| 00h                      | Vref x 1.42             | 10h                    | Vref x 2.85 |
| 01h                      | Vref x 1.50             | 11h                    | Vref x 3.00 |
| 02h                      | Vref x 1.58             | 12h                    | Vref x 3.16 |
| 03h                      | Vref x 1.66             | 13h                    | Vref x 3.32 |
| 04h                      | Vref x 1.74             | 14h                    | Vref x 3.49 |
| 05h                      | Vref x 1.82             | 15h                    | Vref x 3.63 |
| 06h                      | Vref x 1.90             | 16h                    | Vref x 3.79 |
| 07h                      | Vref x 1.97             | 17h                    | Vref x 3.95 |
| 08h                      | Vref x 2.06             | 18h                    | Vref x 4.12 |
| 09h                      | Vref x 2.13             | 19h                    | Vref x 4.28 |
| 0Ah                      | Vref x 2.21             | 1Ah                    | Vref x 4.42 |
| 0Bh                      | Vref x 2.29             | 1Bh                    | Vref x 4.58 |
| 0Ch                      | Vref x 2.37             | 1Ch                    | Vref x 4.75 |
| 0Dh                      | Vref x 2.45             | 1Dh                    | Vref x 4.90 |
| 0Eh                      | Vref x 2.53             | 1Eh                    | Vref x 5.06 |
| 0Fh                      | Vref x 2.69             | 1Fh                    | Vref x 5.23 |
| Note: Vref is the applic | cable voltage reference | e, selected by LDO_REF | SEL.        |

Table 39 LDO Output Voltage Control

| BG_VSEL [4:0] | BG Voltage (V) | BG_VSEL [4:0] | BG Voltage (V) |
|---------------|----------------|---------------|----------------|
| 00h           | 1.200          | 08h           | 1.414          |
| 01h           | 1.227          | 09h           | 1.440          |
| 02h           | 1.253          | 0Ah           | 1.467          |
| 03h           | 1.280          | 0Bh           | 1.494          |
| 04h           | 1.307          | 0Ch           | 1.520          |
| 05h           | 1.334          | 0Dh           | 1.547          |
| 06h           | 1.360          | 0Eh           | 1.574          |
| 07h           | 1.387          | 0Fh           | 1.600          |

Table 40 Bandgap Voltage Control

WM8946 Production Data

#### REFERENCE VOLTAGES AND MASTER BIAS

This section describes the analogue reference voltage and bias current controls. It also describes the VMID soft-start circuit for pop suppressed start-up and shut-down.

The analogue circuits in the WM8946 require a mid-rail analogue reference voltage, VMID. This reference is generated via a programmable resistor chain. Together with the external decoupling capacitor (connected to the VMIDC pin), the programmable resistor chain results in a slow, normal or fast charging characteristic on the VMID reference. This is enabled using VMID\_ENA and VMID\_SEL. The different resistor options controlled by VMID\_SEL can be used to optimize the reference for normal operation, low power standby or for fast start-up as described in Table 41.

The VMID resistor chain can be powered from the LDO output (LDOVOUT) or from the LDO supply (LDOVDD). This is selected using VMID\_REF\_SEL. .

Note that when VMID is selected as the LDO reference voltage, VMID cannot be generated from the LDOVOUT supply voltage (VMID\_REF\_SEL = 1) and must be generated from the LDOVDD supply voltage (VMID\_REF\_SEL = 0).

The VMID ratio can be selected using VMID\_CTRL. This selects the ratio of VMID to the supply voltage that has been selected by VMID\_REF\_SEL. VMID should be half of the LDOVOUT supply voltage for maximum voltage swing. In the case where VMID\_REF\_SEL has selected the LDOVOUT supply voltage output, then VMID\_CTRL should select the ratio "1/2". In the case where VMID\_REF\_SEL has selected the LDOVDD supply voltage, then the alternate ratio "5/11" may be preferred provided LDOVDDD = 3.3V and LDOVOUT = 3.0V.

Note that the "5/11" ratio is designed for the case where LDOVDD = 3.3V and LDOVOUT = 3.0V. This results in a VMID = 3.3V x (5/11) = 1.5V which is half of the LDOVOUT voltage.

If these conditions are not being used or the LDO has been bypassed then VMID\_REF should be set to select LDOVOUT as the VMID source and VMID\_CTRL should be set to select the ratio "1/2".

The analogue circuits in the WM8946 require a bias current. The normal bias current is enabled by setting BIAS\_ENA. Note that the normal bias current source requires VMID to be enabled also.

| REGISTER<br>ADDRESS | BIT | LABEL          | DEFAULT | DESCRIPTION                                                   |
|---------------------|-----|----------------|---------|---------------------------------------------------------------|
| R7 (07h)            | 10  | VMID_REF_SEL   | 0       | VMID Source Select                                            |
| Additional          |     |                |         | 0 = LDO supply (LDOVDD)                                       |
| control             |     |                |         | 1 = LDO output (LDOVOUT)                                      |
|                     | 9   | VMID_CTRL      | 0       | VMID Ratio control                                            |
|                     |     |                |         | Sets the ratio of VMID to the source selected by VMID_REF_SEL |
|                     |     |                |         | 0 = 5/11                                                      |
|                     |     |                |         | 1 = 1/2                                                       |
|                     | 4   | VMID_ENA       | 0       | VMID Enable                                                   |
|                     |     |                |         | 0 = Disabled                                                  |
|                     |     |                |         | 1 = Enabled                                                   |
| R2 (02h)            | 3   | BIAS_ENA       | 0       | Master Bias Enable                                            |
| Power               |     |                |         | 0 = Disabled                                                  |
| Management          |     |                |         | 1 = Enabled                                                   |
| 1                   | 1:0 | VMID_SEL [1:0] | 00      | VMID Divider Enable and Select                                |
|                     |     |                |         | 00 = VMID disabled (for OFF mode)                             |
|                     |     |                |         | 01 = 2 x 50kΩ divider (for normal operation)                  |
|                     |     |                |         | 10 = 2 x 250kΩ divider (for low power standby)                |
|                     |     |                |         | 11 = 2 x 5kΩ divider (for fast start-<br>up)                  |

Table 41 Reference Voltages and Master Bias Enable



A pop-suppressed start-up requires VMID to be enabled smoothly, without the step change normally associated with the initial stage of the VMID capacitor charging. A pop-suppressed start-up also requires the analogue bias current to be enabled throughout the signal path prior to the VMID reference voltage being applied. The WM8946 incorporates pop-suppression circuits which address these requirements.

An alternate bias current source (Start-Up Bias) is provided for pop-free start-up; this is enabled by the STARTUP\_BIAS\_ENA register bit. The start-up bias is selected (in place of the normal bias) using the BIAS\_SRC bit. It is recommended that the start-up bias is used during start-up, before switching back to the higher quality, normal bias.

A soft-start circuit is provided in order to control the switch-on of the VMID reference. The soft-start control circuit offers two slew rates for enabling the VMID reference; these are selected and enabled by VMID\_RAMP. When the soft-start circuit is enabled prior to enabling VMID\_SEL, the reference voltage rises smoothly, without the step change that would otherwise occur. It is recommended that the soft-start circuit and the output signal path be enabled before VMID is enabled by VMID\_SEL.

A soft shut-down is provided, using the soft-start control circuit and the start-up bias current generator. The soft shut-down of VMID is achieved by setting VMID\_RAMP, STARTUP\_BIAS\_ENA and BIAS\_SRC to select the start-up bias current and soft-start circuit prior to setting VMID\_SEL=00.

The internal LDO (described in the previous section) requires a voltage reference. Under normal operating conditions, this is provided from VMID, via the register controls described in Table 41. Note, however, that VMID is normally generated from the LDO output. Therefore, an alternative voltage reference is required for start-up, which is not dependent on the LDO output. The VMID\_FAST\_START bit enables a 'Fast-Start' reference powered from LDOVDD. This alternate VMID can be selected as the LDO reference using the LDO\_REF\_SEL\_FAST bit as described in Table 38.

| The VMID soft-start and | fast start register | controls are | defined in | Table 42. |
|-------------------------|---------------------|--------------|------------|-----------|
|                         |                     |              |            |           |

| REGISTER<br>ADDRESS | BIT | LABEL           | DEFAULT | DESCRIPTION                                |
|---------------------|-----|-----------------|---------|--------------------------------------------|
| R7 (07h)            | 11  | VMID_FAST_STA   | 0       | VMID (fast-start) Enable                   |
| Additional          |     | RT              |         | 0 = Disabled                               |
| control             |     |                 |         | 1 = Enabled                                |
|                     | 8   | STARTUP_BIAS_   | 0       | Start-Up Bias Enable                       |
|                     |     | ENA             |         | 0 = Disabled                               |
|                     |     |                 |         | 1 = Enabled                                |
|                     | 7   | BIAS_SRC        | 0       | Bias Source select                         |
|                     |     |                 |         | 0 = Normal bias                            |
|                     |     |                 |         | 1 = Start-Up bias                          |
|                     | 6:5 | VMID_RAMP [1:0] | 00      | VMID soft start enable / slew rate control |
|                     |     |                 |         | 00 = Disabled                              |
|                     |     |                 |         | 01 = Fast soft start                       |
|                     |     |                 |         | 10 = Normal soft start                     |
|                     |     |                 |         | 11 = Slow soft start                       |

Table 42 Soft Start Control

WM8946 Production Data

## POP SUPPRESSION CONTROL

The WM8946 incorporates a number of features which are designed to suppress pops normally associated with Start-Up, Shut-Down or signal path control. These include the option to maintain an analogue output to VMID even when the output driver is disabled. In addition, there is the ability to actively discharge an output to GND.

Note that, to achieve maximum benefit from these features, careful attention may be required to the sequence and timing of these controls.

## **DISABLED OUTPUT CONTROL**

The line outputs and speaker outputs are biased to VMID in normal operation. In order to avoid audible pops caused by a disabled signal path dropping to GND, the WM8946 can maintain these connections at VMID when the relevant output stage is disabled. This is achieved by connecting a buffered VMID reference to the output.

The buffered VMID reference is enabled by setting VMID\_BUF\_ENA. This is applied to any disabled outputs, provided that the respective \_VMID\_OP\_ENA bit is also set. The output resistance can be either  $1k\Omega$  or  $20k\Omega$ , depending on the respective \_VROI register bit.

The disabled output control bits are described in Table 43. See "Output Signal Path" for details of how to disable any of the audio outputs.

| REGISTER<br>ADDRESS      | BIT | LABEL                 | DEFAULT | DESCRIPTION                                                              |
|--------------------------|-----|-----------------------|---------|--------------------------------------------------------------------------|
| R2 (02h)                 | 2   | VMID_BUF_ENA          | 0       | VMID Buffer Enable.                                                      |
| Power management         |     |                       |         | (The buffered VMID may be applied to disabled input and output pins.)    |
| 1                        |     |                       |         | 0 = Disabled                                                             |
|                          |     |                       |         | 1 = Enabled                                                              |
| R42 (2Ah)<br>Output ctrl | 13  | SPKR_VMID_OP<br>_ENA  | 0       | Buffered VMID to SPKOUTR<br>Enable                                       |
|                          |     |                       |         | 0 = Disabled                                                             |
|                          |     |                       |         | 1 = Enabled                                                              |
|                          | 12  | SPKL_VMID_OP_         | 0       | Buffered VMID to SPKOUTL Enable                                          |
|                          |     | ENA                   |         | 0 = Disabled                                                             |
|                          |     |                       |         | 1 = Enabled                                                              |
|                          | 11  | LINER_VMID_OP<br>_ENA | 0       | Buffered VMID to LINEOUTR<br>Enable                                      |
|                          |     |                       |         | 0 = Disabled                                                             |
|                          |     |                       |         | 1 = Enabled                                                              |
|                          | 10  | LINEL_VMID_OP<br>_ENA | 0       | Buffered VMID to LINEOUTL<br>Enable                                      |
|                          |     |                       |         | 0 = Disabled                                                             |
|                          |     |                       |         | 1 = Enabled                                                              |
|                          | 1   | SPK_VROI              | 0       | Buffered VREF to SPKOUTL /<br>SPKOUTR resistance (Disabled<br>outputs)   |
|                          |     |                       |         | 0 = approx 20k                                                           |
|                          |     |                       |         | 1 = approx 1k                                                            |
|                          | 0   | LINE_VROI             | 0       | Buffered VREF to LINEOUTL /<br>LINEOUTR resistance (Disabled<br>outputs) |
|                          |     |                       |         | 0 = approx 20k                                                           |
|                          |     |                       |         | 1 = approx 1k                                                            |

**Table 43 Disabled Output Control** 



#### **OUTPUT DISCHARGE CONTROL**

The line outputs and speaker outputs can be actively discharged to GND through internal resistors if desired. This is desirable at start-up in order to achieve a known output stage condition prior to enabling the soft-start VMID reference voltage. This is also desirable in shut-down to prevent the external connections from being affected by the internal circuits.

The individual control bits for discharging each audio output are described in Table 44.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                       |
|---------------------|-----|-------------|---------|---------------------------------------------------|
| R42 (2Ah)           | 7   | SPKR_DISCH  | 0       | Discharges SPKOUTR output via approx 4k resistor  |
| Output ctrl         |     |             |         | 0 = Not active                                    |
|                     |     |             |         | 1 = Actively discharging SPKOUTR                  |
|                     | 6   | SPKL_DISCH  | 0       | Discharges SPKOUTL output via approx 4k resistor  |
|                     |     |             |         | 0 = Not active                                    |
|                     |     |             |         | 1 = Actively discharging SPKOUTL                  |
|                     | 5   | LINER_DISCH | 0       | Discharges LINEOUTR output via approx 4k resistor |
|                     |     |             |         | 0 = Not active                                    |
|                     |     |             |         | 1 = Actively discharging LINEOUTR                 |
|                     | 4   | LINEL_DISCH | 0       | Discharges LINEOUTL output via approx 4k resistor |
|                     |     |             |         | 0 = Not active                                    |
|                     |     |             |         | 1 = Actively discharging LINEOUTL                 |

**Table 44 Output Discharge Control** 

## **DIGITAL AUDIO INTERFACE**

The digital audio interface is used for inputting DAC data into the WM8946 and outputting ADC data from it. It uses four pins:

ADCDAT: ADC data output

DACDAT: DAC data input

LRCLK: DAC and ADC data alignment clock

BCLK: Bit clock, for synchronisation

#### **MASTER AND SLAVE MODE OPERATION**

The digital audio interface can be configured as a Master or a Slave interface, using the MSTR register bit. The two modes are illustrated in Figure 21 and Figure 22.



Figure 21 Master Mode

Figure 22 Slave Mode

In Master mode, LRCLK and BCLK are configured as outputs, and the WM8946 controls the timing of the data transfer on the ADCDAT and DACDAT pins.

In Master mode, the LRCLK frequency is determined automatically according to the sample rate (see "Clocking and Sample Rates"). The BCLK frequency is set by the BCLK\_DIV register. BCLK\_DIV must be set to an appropriate value to ensure that there are sufficient BCLK cycles to transfer the complete data words from the ADCs and to the DACs.

In Slave mode, LRCLK and BCLK are configured as inputs, and the data timing is controlled by an external master.

| REGISTER<br>ADDRESS | BIT | LABEL          | DEFAULT | DESCRIPTION                         |
|---------------------|-----|----------------|---------|-------------------------------------|
| R6 (06h)            | 3:1 | BCLK_DIV [2:0] | 011     | BCLK Frequency (Master mode)        |
| Clock Gen           |     |                |         | 000 = SYSCLK                        |
| control             |     |                |         | 001 = SYSCLK / 2                    |
|                     |     |                |         | 010 = SYSCLK / 4                    |
|                     |     |                |         | 011 = SYSCLK / 8                    |
|                     |     |                |         | 100 = SYSCLK / 16                   |
|                     |     |                |         | 101 = SYSCLK / 32                   |
|                     |     |                |         | 110 = reserved                      |
|                     |     |                |         | 111 = reserved                      |
|                     | 0   | MSTR           | 0       | Digital Audio Interface Mode select |
|                     |     |                |         | 0 = Slave mode                      |
|                     |     |                |         | 1 = Master mode                     |

**Table 45 Digital Audio Interface Control** 

## **AUDIO DATA FORMATS**

Three basic audio data formats are supported:

- Left justified
- I<sup>2</sup>S
- DSP mode

All four of these modes are MSB first. They are described in Audio Data Formats, below. Refer to the Electrical Characteristic section for timing information.

PCM operation is supported using the DSP mode.

The WM8946 can control the channel selection between the ADCs and the ADCDAT pin. Similarly, the channel selection between the DACDAT pin and the DACs is selectable. Digital inversion of the ADC or DAC data is also possible.

The register bits controlling audio data format and channel configuration are described in Table 46.

| REGISTER<br>ADDRESS            | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                                                     |
|--------------------------------|-----|----------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| R4 (04h)<br>Audio<br>Interface | 9   | ADCR_SRC | 1       | Right Digital Audio interface source 0 = Left ADC data is output on right channel 1 = Right ADC data is output on right channel |
|                                | 8   | ADCL_SRC | 0       | Left Digital Audio interface source 0 = Left ADC data is output on left channel 1 = Right ADC data is output on left channel    |



| REGISTER<br>ADDRESS        | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                                                   |
|----------------------------|-----|-------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
|                            | 7   | DACR_SRC    | 1       | Right DAC Data Source Select 0 = Right DAC outputs left interface data 1 = Right DAC outputs right interface data             |
|                            | 6   | DACL_SRC    | 0       | Left DAC Data Source Select  0 = Left DAC outputs left interface                                                              |
|                            |     |             |         | data 1 = Left DAC outputs right interface data                                                                                |
|                            | 5   | BCLK_INV    | 0       | BCLK Invert 0 = BCLK not inverted 1 = BCLK inverted                                                                           |
|                            | 4   | LRCLK_INV   | 0       | LRCLK Polarity / DSP Mode A-B select.                                                                                         |
|                            |     |             |         | Right, left and I <sup>2</sup> S modes – LRCLK polarity 0 = Not Inverted                                                      |
|                            |     |             |         | 1 = Inverted                                                                                                                  |
|                            |     |             |         | DSP Mode – Mode A-B select<br>0 = MSB is available on 2 <sup>nd</sup> BCLK<br>rising edge after LRCLK rising edge<br>(mode A) |
|                            |     |             |         | 1 = MSB is available on 1 <sup>st</sup> BCLK<br>rising edge after LRCLK rising edge<br>(mode B)                               |
|                            | 3:2 | WL [1:0]    | 10      | Digital Audio Interface Word Length 00 = 16 bits                                                                              |
|                            |     |             |         | 01 = 20 bits<br>10 = 24 bits<br>11 = 32 bits                                                                                  |
|                            |     |             |         | Note – see "Companding" for the selection of 8-bit mode.                                                                      |
|                            | 1:0 | FMT [1:0]   | 10      | Digital Audio Interface Format  00 = Reserved  01 = Left Justified  10 = I2S format                                           |
| R21 (15h)                  | 1   | DACR_DATINV | 0       | 11 = DSP/PCM mode Right DAC Invert                                                                                            |
| DAC Control 1              |     |             |         | 0 = Right DAC output not inverted<br>1 = Right DAC output inverted                                                            |
|                            | 0   | DACL_DATINV | 0       | Left DAC Invert  0 = Left DAC output not inverted  1 = Left DAC output inverted                                               |
| R25 (19h)<br>ADC Control 1 | 1   | ADCR_DATINV | 0       | Right ADC Invert  0 = Right ADC output not inverted  1 = Right ADC output inverted                                            |
|                            | 0   | ADCL_DATINV | 0       | Left ADC Invert 0 = Left ADC output not inverted 1 = Left ADC output inverted                                                 |

**Table 46 Audio Data Format Control** 



In Left Justified mode, the MSB is available on the first rising edge of BCLK following a LRCLK transition. The other bits up to the LSB are then transmitted in order. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles before each LRCLK transition.



Figure 23 Left Justified Audio Interface (assuming n-bit word length)

In I<sup>2</sup>S mode, the MSB is available on the second rising edge of BCLK following a LRCLK transition. The other bits up to the LSB are then transmitted in order. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles between the LSB of one sample and the MSB of the next.



Figure 24 I<sup>2</sup>S Justified Audio Interface (assuming n-bit word length)

In DSP/PCM mode, the left channel MSB is available on either the 1<sup>st</sup> (mode B) or 2<sup>nd</sup> (mode A) rising edge of BCLK (selected by LRCLK\_INV) following a rising edge of LRCLK. Right channel data immediately follows left channel data. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles between the LSB of the right channel data and the next sample.

In device master mode, the LRCLK output resembles the frame pulse shown in Figure 25 and Figure 26. In device slave mode, Figure 27 and Figure 28, it is possible to use any length of frame pulse less than 1/fs, providing the falling edge of the frame pulse occurs greater than one BCLK period before the rising edge of the next frame pulse.



Figure 25 DSP/PCM Mode Audio Interface (mode A, LRCLK\_INV=0, Master)





Figure 26 DSP/PCM Mode Audio Interface (mode B, LRCLK\_INV=1, Master)



Figure 27 DSP/PCM Mode Audio Interface (mode A, LRCLK\_INV=0, Slave)



Figure 28 DSP/PCM Mode Audio Interface (mode B, LRCLK\_INV=0, Slave)

### **COMPANDING**

The WM8946 supports A-law and  $\mu$ -law companding on both transmit (ADC) and receive (DAC) sides as shown in Table 47. Companding converts 13 bits ( $\mu$ -law) or 12 bits (A-law) to 8 bits using nonlinear quantization. This provides greater precision for low-amplitude signals than for high-amplitude signals, resulting in a greater usable dynamic range than 8 bit linear quantization.

| REGISTER<br>ADDRESS | BIT | LABEL            | DEFAULT | DESCRIPTION           |
|---------------------|-----|------------------|---------|-----------------------|
| R5 (05h)            | 3   | DAC_COMP         | 0       | DAC Companding Enable |
| Companding          |     |                  |         | 0 = Disabled          |
| control             |     |                  |         | 1 = Enabled           |
|                     | 2   | DAC_COMPMO<br>DE | 0       | DAC Companding Mode   |
|                     |     |                  |         | 0 = μ-law             |
|                     |     |                  |         | 1 = A-law             |
|                     | 1   | ADC_COMP         | 0       | ADC Companding Enable |
|                     |     |                  |         | 0 = Disabled          |
|                     |     |                  |         | 1 = Enabled           |
|                     | 0   | ADC_COMPMO       | 0       | ADC Companding Mode   |
|                     |     | DE               |         | 0 = μ-law             |
|                     |     |                  |         | 1 = A-law             |

**Table 47 Companding Control** 

Companding uses a piecewise linear approximation of the following equations (as set out by ITU-T G.711 standard) for data compression:

 $\mu\text{-law}$  (where  $\mu\text{=}255$  for the U.S. and Japan):

$$F(x) = \ln(1 + \mu |x|) / \ln(1 + \mu)$$
 } for  $-1 \le x \le 1$ 

Table 1 law (where A=87.6 for Europe):

$$F(x) = A|x| / (1 + InA)$$
 } for  $x \le 1/A$ 

F(x) = (1 + InA|x|) / (1 + InA) } for  $1/A \le x \le 1$ 



Figure 29 µ-Law Companding



Figure 30 A-Law Companding

The companded data is also inverted as recommended by the G.711 standard (all 8 bits are inverted for  $\mu$ -law, all even data bits are inverted for A-law). Companded data is transmitted in the first 8 MSBs of its respective data word, and consists of sign (1 bit), exponent (3 bits) and mantissa (4 bits), as shown in Table 48.

| BIT7 | BIT[6:4] | BIT[3:0] |
|------|----------|----------|
| SIGN | EXPONENT | MANTISSA |

Table 48 8-bit Companded Word Composition

8-bit mode is selected whenever DAC\_COMP=1 or ADC\_COMP=1. The use of 8-bit data allows samples to be passed using as few as 8 BCLK cycles per Left/Right Clock frame. When using DSP mode B, 8-bit data words may be transferred consecutively every 8 BCLK cycles.

8-bit mode (without Companding) may be enabled by setting DAC\_COMPMODE=1 or ADC\_COMPMODE=1, when DAC\_COMP=0 and ADC\_COMP=0.

### LOOPBACK

A loopback function is provided for test and evaluation purposes. When the LOOPBACK register bit is set, the DAC input data is fed through the DSP Core to the ADC output, as illustrated in Figure 31.



Figure 31 Audio Interface Loopback

| REGISTER<br>ADDRESS               | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                                                       |
|-----------------------------------|-----|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| R5 (05h)<br>Companding<br>control | 5   | LOOPBACK | 0       | Digital Loopback Function  0 = No loopback  1 = Loopback enabled (DACDAT input is fed through the DSP Core to the ADCDAT output). |

**Table 49 Loopback Control** 

#### **DIGITAL PULL-UP AND PULL-DOWN**

The WM8946 provides integrated pull-up and pull-down resistors on each of the DACDAT, LRCLK and BCLK pins. This provides a flexible capability for interfacing with other devices. Each of the pull-up and pull-down resistors can be configured independently using the register bits described in Table 50.

| REGISTER<br>ADDRESS | BIT   | LABEL               | DEFAULT | DESCRIPTION                       |
|---------------------|-------|---------------------|---------|-----------------------------------|
| R4 (04h)            | 15:14 | DACDATA_PUL         | 00      | DACDAT pull-up / pull-down Enable |
| Audio               |       | L [1:0]             |         | 00 = no pull-up or pull-down      |
| interface           |       |                     |         | 01 = pull-down                    |
|                     |       |                     |         | 10 = pull-up                      |
|                     |       |                     |         | 11 = reserved                     |
|                     | 13:12 | FRAME_PULL<br>[1:0] | 00      | LRCLK pull-up / pull-down Enable  |
|                     |       |                     |         | 00 = no pull-up or pull-down      |
|                     |       |                     |         | 01 = pull-down                    |
|                     |       |                     |         | 10 = pull-up                      |
|                     |       |                     |         | 11 = reserved                     |
|                     | _     | BCLK_PULL<br>[1:0]  | 00      | BCLK pull-up / pull-down Enable   |
|                     |       |                     |         | 00 = no pull-up or pull-down      |
|                     |       |                     |         | 01 = pull-down                    |
|                     |       |                     |         | 10 = pull-up                      |
|                     |       |                     |         | 11 = reserved                     |

Table 50 Pull-Up and Pull-Down Control

### **CLOCKING AND SAMPLE RATES**

The internal clocks for the CODEC and Digital Audio Interface are derived from a common internal clock source, SYSCLK. This clock can either be derived directly from MCLK, or may be generated using the Frequency Locked Loop (FLL) using MCLK as a reference. All commonly-used audio sample rates can be derived directly from typical MCLK frequencies; the FLL provides additional flexibility for a wider range of MCLK frequencies.

The WM8946 supports a wide range of standard audio sample rates from 8kHz to 48kHz. When the ADC and DAC are both enabled, they operate at the same sample rate, fs.

Other functions such as the Interrupts, GPIO input de-bounce and PGA zero-cross timeouts are clocked using a free-running oscillator.

The control registers associated with Clocking and Sample Rates are described in Table 51.

The overall clocking scheme for the WM8946 is illustrated in Figure 32.



Figure 32 WM8946 Clocking Overview

SYSCLK may be derived either from MCLK or from the FLL; this is selected using the SYSCLK\_SRC register bit. SYSCLK is enabled using the SYSCLK\_ENA and may be modified using a programmable divider configured by SYSCLK\_DIV. It is important that SYSCLK\_DIV is correctly set in order to produce 512 x fs at its output, where fs is the audio sampling rate.

The sampling rate for the CODEC and Digital Audio Interface is configured using the SR register field. In Master mode, the frequency of the Left/Right Clock output on the LRCLK pin is the BCLK frequency divided by 64 producing 32 BCLK cycles per channel. In Master mode, the BCLK\_DIV register configures the bit clock frequency output on BCLK.

The WM8946 can output a configurable clock on the GPIO pins; this is enabled automatically whenever a GPIO pin is configured for CLKOUT output. The source can either be before or after the SYSCLK divider, as shown in Figure 32. The source is selected using CLKOUT\_SEL, and may be modified using a programmable divider configured by CLKOUT\_DIV.

The WM8946 free-running oscillator required for GPIO input de-bounce and Interrupt functions must be enabled using OSC\_CLK\_ENA whenever any of these functions is required.

The zero-cross facility on input and output PGAs requires a timeout clock. This is enabled using the TOCLK ENA bit. The oscillator must also be enabled using OSC CLK ENA.

| REGISTER<br>ADDRESS | BIT                                  | LABEL       | DEFAULT | DESCRIPTION                                                                                      |
|---------------------|--------------------------------------|-------------|---------|--------------------------------------------------------------------------------------------------|
| R6 (06h)            | 15                                   | OSC_CLK_ENA | 0       | Oscillator Enable                                                                                |
| Clock Gen           |                                      |             |         | 0 = Disabled                                                                                     |
| control             |                                      |             |         | 1 = Enabled                                                                                      |
|                     |                                      |             |         | This needs to be set when a timeout clock is required for PGA zero cross or GPIO input detection |
|                     | 14:13 MCLK_PULL [1:0]  12 CLKOUT_SEL | _           | 00      | MCLK pull-up / pull-down Enable                                                                  |
|                     |                                      |             |         | 00 = no pull-up or pull-down                                                                     |
|                     |                                      |             |         | 01 = pull-down                                                                                   |
|                     |                                      |             |         | 10 = pull-up                                                                                     |
|                     |                                      |             |         | 11 = reserved                                                                                    |
|                     |                                      | CLKOUT_SEL  | 0       | CLKOUT Source Select                                                                             |
|                     |                                      |             |         | 0 = SYSCLK                                                                                       |
|                     |                                      |             |         | 1 = FLL or MCLK (set by SYSCLK_SRC register)                                                     |



| REGISTER<br>ADDRESS | BIT   | LABEL      | DEFAULT | DESCRIPTION                                                                             |
|---------------------|-------|------------|---------|-----------------------------------------------------------------------------------------|
|                     | 11:10 | CLKOUT_DIV | 00      | CLKOUT Clock divider                                                                    |
|                     |       | [1:0]      |         | 00 = divide by 1                                                                        |
|                     |       |            |         | 01 = divide by 2                                                                        |
|                     |       |            |         | 10 = divide by 4                                                                        |
|                     |       |            |         | 11 = divide by 8                                                                        |
|                     | 9     | SYSCLK_ENA | 0       | SYSCLK Enable                                                                           |
|                     |       |            |         | 0 = Disabled                                                                            |
|                     |       |            |         | 1 = Enabled                                                                             |
|                     | 8     | SYSCLK_SRC | 0       | SYSCLK Source Select                                                                    |
|                     |       |            |         | 0 = MCLK                                                                                |
|                     |       |            |         | 1 = FLL output                                                                          |
|                     | 7:5   | SYSCLK_DIV | 000     | SYSCLK Clock divider                                                                    |
|                     |       | [2:0]      |         | (Sets the scaling for either the MCLK or FLL clock output, depending on SYSCLK_SRC)     |
|                     |       |            |         | 000 = divide by 1                                                                       |
|                     |       |            |         | 001 = divide by 1.5                                                                     |
|                     |       |            |         | 010 = divide by 2                                                                       |
|                     |       |            |         | 011 = divide by 3                                                                       |
|                     |       |            |         | 100 = divide by 4                                                                       |
|                     |       |            |         | 101 = divide by 6                                                                       |
|                     |       |            |         | 110 = divide by 8                                                                       |
|                     |       |            |         | 111 = divide by 12                                                                      |
|                     | 4     | TOCLK_ENA  | 0       | TOCLK Enabled                                                                           |
|                     |       |            |         | (Enables timeout clock for GPIO<br>level detection, AMU, and PGA zero<br>cross timeout) |
|                     |       |            |         | 0 = Disabled                                                                            |
|                     |       |            |         | 1 = Enabled                                                                             |
| R7 (07h)            | 3:0   | SR [3:0]   | 1101    | Audio Sample Rate select                                                                |
| Additional          |       |            |         | 0011 = 8kHz                                                                             |
| control             |       |            |         | 0100 = 11.025kHz                                                                        |
|                     |       |            |         | 0101 = 12kHz                                                                            |
|                     |       |            |         | 0111 = 16kHz                                                                            |
|                     |       |            |         | 1000 = 22.05kHz                                                                         |
|                     |       |            |         | 1001 = 24kHz                                                                            |
|                     |       |            |         | 1011 = 32kHz                                                                            |
|                     |       |            |         | 1100 = 44.1kHz                                                                          |
|                     |       |            |         | 1101 = 48kHz                                                                            |

Table 51 Clocking and Sample Rate Control

#### **DIGITAL MIC CLOCKING**

When any GPIO is configured as DMICCLK output, the WM8946 outputs a clock which supports Digital Mic operation at the ADC sampling rate. Although the ADC is not used, the SYSCLK and Sample Rate control fields must still be set as they would for ADC operation.

The clock frequencies for each of the sample rates is shown in Table 52.

| PCM SAMPLE RATE | DMICCLK   | FS RATE |
|-----------------|-----------|---------|
| 8kHz            | 1.024MHz  | 128fs   |
| 11.025kHz       | 1.411MHz  | 128fs   |
| 12kHz           | 1.536MHz  | 128fs   |
| 16kHz           | 2.048MHz  | 128fs   |
| 22.05kHz        | 2.8224MHz | 128fs   |
| 24kHz           | 3.072MHz  | 128fs   |
| 32kHz           | 2.048MHz  | 64fs    |
| 44.1kHz         | 2.8224MHz | 64fs    |
| 48kHz           | 3.072MHz  | 64fs    |

Table 52 Digital Microphone Clock Frequencies

#### FREQUENCY LOCKED LOOP (FLL)

The integrated FLL can be used to generate SYSCLK from a wide variety of different reference sources and frequencies. The FLL uses MCLK as its reference, which may be a high frequency (e.g. 12.288MHz) or low frequency (e.g. 32,768kHz) reference. The FLL is tolerant of jitter and may be used to generate a stable SYSCLK from a less stable input signal. The FLL characteristics are summarised in "Electrical Characteristics".

The FLL is enabled using the FLL\_ENA register bit. At initial power on the VMID voltage must be allowed to settle at its final vale before enabling the FLL. Note that, when changing FLL settings, it is recommended that the digital circuit be disabled via FLL\_ENA and then re-enabled after the other register settings have been updated. When changing the input reference frequency  $F_{REF}$ , it is recommended that the FLL be reset by setting FLL\_ENA to 0.

The field FLL\_CLK\_REF\_DIV provides the option to divide the input reference (MCLK) by 1, 2, 4 or 8. This field should be set to bring the reference down to 13.5MHz or below. For best performance, it is recommended that the highest possible frequency – within the 13.5MHz limit – should be selected.

The field FLL\_CTRL\_RATE controls internal functions within the FLL; it is recommended that only the default setting be used for this parameter. FLL\_GAIN controls the internal loop gain and should be set to the recommended value.

The FLL output frequency is directly determined from FLL\_FRATIO, FLL\_OUTDIV and the real number represented by FLL\_N and FLL\_K. The field FLL\_N is an integer (LSB = 1); FLL\_K is the fractional portion of the number (MSB = 0.5). The fractional portion is only valid when enabled by the field FLL\_FRAC.

Power consumption in the FLL is reduced in integer mode; however, the performance may also be reduced, with increased noise or jitter on the output.

If low power consumption is required, then FLL settings must be chosen where N.K is an integer (i.e.  $FLL_K = 0$ ). In this case, the fractional mode can be disabled by setting  $FLL_FRAC = 0$ .

For best FLL performance, a non-integer value of N.K is required. In this case, the fractional mode must be enabled by setting FLL\_FRAC = 1. The FLL settings must be adjusted, if necessary, to produce a non-integer value of N.K.

The FLL output frequency is generated according to the following equation:

$$F_{OUT} = (F_{VCO} / FLL_OUTDIV)$$



The FLL operating frequency, F<sub>VCO</sub> is set according to the following equation:

$$F_{VCO} = (F_{REF} \times N.K \times FLL_FRATIO)$$

 $F_{\text{REF}}$  is the input frequency, as determined by FLL\_CLK\_REF\_DIV.

F<sub>VCO</sub> must be in the range 90-100 MHz. Frequencies outside this range cannot be supported.

Note that the output frequencies that do not lie within the ranges quoted above cannot be guaranteed across the full range of device operating temperatures.

In order to follow the above requirements for  $F_{VCO}$ , the value of FLL\_OUTDIV should be selected according to the desired output  $F_{OUT}$ , as described in Table 53.

| OUTPUT FREQUENCY F <sub>OUT</sub> | FLL_OUTDIV        |
|-----------------------------------|-------------------|
| 2.8125 MHz – 3.125 MHz            | 4h (divide by 32) |
| 5.625 MHz – 6.25 MHz              | 3h (divide by 16) |
| 11.25 MHz – 12.5 MHz              | 2h (divide by 8)  |
| 22.5 MHz – 25 MHz                 | 1h (divide by 4)  |
| 45 MHz – 50 MHz                   | 0h (divide by 2)  |

Table 53 Selection of FLL\_OUTDIV

The value of FLL FRATIO should be selected as described in Table 54.

| REFERENCE FREQUENCY F <sub>REF</sub> | FLL_FRATIO        |
|--------------------------------------|-------------------|
| 1MHz – 13.5MHz                       | 0h (divide by 1)  |
| 256kHz – 1MHz                        | 1h (divide by 2)  |
| 128kHz – 256kHz                      | 2h (divide by 4)  |
| 16kHz – 128kHz                       | 3h (divide by 8)  |
| Less than 16kHz                      | 4h (divide by 16) |

Table 54 Selection of FLL\_FRATIO

In order to determine the remaining FLL parameters, the FLL operating frequency,  $F_{VCO}$ , must be calculated, as given by the following equation:

$$F_{VCO} = (F_{OUT} x FLL_OUTDIV)$$

The value of FLL\_N and FLL\_K can then be determined as follows:

$$N.K = F_{VCO} / (FLL_FRATIO x F_{REF})$$

Note that F<sub>REF</sub> is the input frequency, after division by FLL\_CLK\_REF\_DIV, where applicable.

In FLL Fractional Mode, the fractional portion of the N.K multiplier is held in the FLL\_K register field. This field is coded as a fixed point quantity, where the MSB has a weighting of 0.5. Note that, if desired, the value of this field may be calculated by multiplying K by 2^16 and treating FLL\_K as an integer value, as illustrated in the following example:

If 
$$N.K = 8.192$$
, then  $K = 0.192$ .

Multiplying K by 2^16 gives 0.192 x 65536 = 12582.912 (decimal) = 3126 (hex).



For best FLL performance, the FLL fractional mode is recommended. Therefore, if the calculations yield an integer value of N.K, then it is recommended to adjust FLL\_FRATIO in order to obtain a non-integer value of N.K. Care must always be taken to ensure that the FLL operating frequency,  $F_{VCO}$ , is within its recommended limits of 90-100 MHz.

The register fields that control the FLL are described in Table 55. Example settings for a variety of reference frequencies and output frequencies are shown in Table 56.

| REGISTER<br>ADDRESS       | BIT   | LABEL                                                                                                          | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                                                        |  |
|---------------------------|-------|----------------------------------------------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| R8 (08h)<br>FLL Control 1 | 12:11 | 1 FLL_CLK_RE F_DIV [1:0] 00 FLL Clock Reference Divide 00 = MCLK / 1 01 = MCLK / 2 10 = MCLK / 4 11 = MCLK / 8 |         |                                                                                                                                                                                                                                                                                    |  |
|                           |       |                                                                                                                |         | MCLK must be divided down to <=13.5MHz.  For lower power operation, the reference clock can be divided down further if desired.                                                                                                                                                    |  |
|                           | 10:8  | FLL_OUTDIV<br>[2:0]                                                                                            | 001     | F <sub>OUT</sub> clock divider<br>000 = 2<br>001 = 4<br>010 = 8<br>011 = 16<br>100 = 32<br>101 = 64<br>110 = 128<br>111 = 256<br>(F <sub>OUT</sub> = F <sub>VCO</sub> / FLL_OUTDIV)                                                                                                |  |
|                           | 7:5   | FLL_CTRL_R<br>ATE [2:0]                                                                                        | 000     | Frequency of the FLL control block $000 = F_{VCO} / 1$ (Recommended value) $001 = F_{VCO} / 2$ $010 = F_{VCO} / 3$ $011 = F_{VCO} / 4$ $100 = F_{VCO} / 5$ $101 = F_{VCO} / 6$ $110 = F_{VCO} / 7$ $111 = F_{VCO} / 8$ Recommended that this register is not changed from default. |  |
|                           | 4:2   | FLL_FRATIO<br>[2:0]                                                                                            | 000     | $F_{VCO}$ clock divider $000 = 1$ $001 = 2$ $010 = 4$ $011 = 8$ $1XX = 16$ $000$ recommended for $F_{REF} > 1$ MHz $100$ recommended for $F_{REF} < 16$ kHz $011$ recommended for all other cases                                                                                  |  |



| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT     | DESCRIPTION                                                                                                                                |
|---------------------|------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 1    | FLL_FRAC    | 1           | Fractional enable                                                                                                                          |
|                     |      |             |             | 0 = Integer Mode                                                                                                                           |
|                     |      |             |             | 1 = Fractional Mode                                                                                                                        |
|                     |      |             |             | Integer mode offers reduced power consumption. Fractional mode offers best FLL performance, provided also that N.K is a non-integer value. |
|                     | 0    | FLL_ENA     | 0           | FLL Enable                                                                                                                                 |
|                     |      |             |             | 0 = Disabled                                                                                                                               |
|                     |      |             |             | 1 = Enabled                                                                                                                                |
| R9 (09h)            | 15:0 | FLL_K[15:0] | 3137h       | Fractional multiply for F <sub>REF</sub>                                                                                                   |
| FLL Control 2       |      |             | (MSB = 0.5) |                                                                                                                                            |
| R10 (0Ah)           | 14:5 | FLL_N[9:0]  | 008h        | Integer multiply for F <sub>REF</sub>                                                                                                      |
| FLL Control 3       |      |             |             | (LSB = 1)                                                                                                                                  |
|                     | 3:0  | FLL_GAIN    | 0100        | Gain applied to error                                                                                                                      |
|                     |      | [3:0]       |             | 0000 = x 1 (Recommended value)                                                                                                             |
|                     |      |             |             | 0001 = x 2                                                                                                                                 |
|                     |      |             |             | 0010 = x 4                                                                                                                                 |
|                     |      |             |             | 0011 = x 8                                                                                                                                 |
|                     |      |             |             | 0100 = x 16                                                                                                                                |
|                     |      |             |             | 0101 = x 32                                                                                                                                |
|                     |      |             |             | 0110 = x 64                                                                                                                                |
|                     |      |             |             | 0111 = x 128                                                                                                                               |
|                     |      |             |             | 1000 = x 256                                                                                                                               |
|                     |      |             |             | Recommended that this register is set to 0000.                                                                                             |

Table 55 Frequency Locked Loop Control

#### **EXAMPLE FLL CALCULATION**

To generate 24.576MHz output ( $F_{OUT}$ ) from a 12.000MHz reference clock ( $F_{REF}$ ):

- Set FLL\_CLK\_REF\_DIV in order to generate F<sub>REF</sub> <=13.5MHz: FLL\_CLK\_REF\_DIV = 00 (divide by 1)
- Set FLL\_CTRL\_RATE to the recommended setting: FLL\_CTRL\_RATE = 000 (divide by 1)
- Sett FLL\_GAIN to the recommended setting: FLL\_GAIN = 0000 (multiply by 1)
- Set FLL\_OUTDIV for the required output frequency as shown in Table 53:-F<sub>OUT</sub> = 24.576MHz, therefore FLL\_OUTDIV = 1h (divide by 4)
- Set FLL\_FRATIO for the given reference frequency as shown in Table 54:
   F<sub>REF</sub> = 12MHz, therefore FLL\_FRATIO = 0h (divide by 1)
- Calculate F<sub>VCO</sub> as given by F<sub>VCO</sub> = F<sub>OUT</sub> x FLL\_OUTDIV:-F<sub>VCO</sub> = 24.576 x 4 = 98.304MHz
- Calculate N.K as given by N.K =  $F_{VCO}$  / (FLL\_FRATIO x  $F_{REF}$ ): N.K = 98.304 / (1 x 12) = 8.192
- Determine FLL\_N and FLL\_K from the integer and fractional portions of N.K:-FLL\_N is 8(dec) = 008(hex). FLL\_K is 0.192 (dec) = 3127(hex).
- Confirm that N.K is a fractional quantity and set FLL\_FRAC:
   N.K is fractional. Set FLL\_FRAC = 1.

   Note that, if N.K is an integer, then an alternative value of FLL\_FRATIO may be selected in order to produce a fractional value of N.K.



### **EXAMPLE FLL SETTINGS**

Table 56 provides example FLL settings for generating common SYSCLK frequencies from a variety of low and high frequency reference inputs.

| F <sub>REF</sub> | F <sub>OUT</sub> | FLL_CLK_<br>REF_DIV | F <sub>vco</sub> | FLL_N  | FLL_K   | FLL_<br>FRATIO | FLL_<br>OUTDIV | FLL_<br>FRAC |
|------------------|------------------|---------------------|------------------|--------|---------|----------------|----------------|--------------|
| 8.000            | 22.5792          | divide by 1         | 90.3168          | 705    | 0.6     | 16             | 4              | 1            |
| kHz              | MHz              | (0h)                | MHz              | (2C1h) | (9999h) | (4h)           | (1h)           |              |
| 8.000            | 24.576           | divide by 1         | 98.304           | 768    | 0.0     | 16             | 4              | 0            |
| kHz              | MHz              | (0h)                | MHz              | (300h) | (0000h) | (4h)           | (1h)           |              |
| 32.768           | 22.5792          | divide by 1         | 90.3168          | 344    | 0.53125 | 8              | 4              | 1            |
| kHz              | MHz              | (0h)                | MHz              | (158h) | (8800h) | (3h)           | (1h)           |              |
| 32.768           | 24.576           | divide by 1         | 98.304           | 375    | 0.0     | 8              | 4              | 0            |
| kHz              | MHz              | (0h)                | MHz              | (177h) | (0000h) | (3h)           | (1h)           |              |
| 768.000          | 22.5792          | divide by 1         | 90.3168          | 14     | 0.7     | 8              | 4              | 1            |
| kHz              | MHz              | (0h)                | MHz              | (00Eh) | (B333h) | (3h)           | (1h)           |              |
| 768.000          | 24.576           | divide by 1         | 98.304           | 16     | 0.0     | 8              | 4              | 0            |
| kHz              | MHz              | (0h)                | MHz              | (010h) | (0000h) | (3h)           | (1h)           |              |
| 1.024            | 22.5792          | divide by 1         | 90.3168          | 88     | 0.2     | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (058h) | (3333h) | (0h)           | (1h)           |              |
| 1.024            | 24.576           | divide by 1         | 98.304           | 96     | 0.0     | 1              | 4              | 0            |
| MHz              | MHz              | (0h)                | MHz              | (060h) | (0000h) | (0h)           | (1h)           |              |
| 6.144            | 22.5792          | divide by 1         | 90.3168          | 14     | 0.7     | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (00Eh) | (B333h) | (0h)           | (1h)           |              |
| 6.144            | 24.576           | divide by 1         | 98.304           | 16     | 0.0     | 1              | 4              | 0            |
| MHz              | MHz              | (0h)                | MHz              | (010h) | (0000h) | (0h)           | (1h)           |              |
| 11.2896          | 22.5792          | divide by 1         | 90.3168          | 8      | 0.0     | 1              | 4              | 0            |
| MHz              | MHz              | (0h)                | MHz              | (008h) | (0000h) | (0h)           | (1h)           |              |
| 11.2896          | 24.576           | divide by 1         | 98.304           | 8      | 0.70749 | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (008h) | (B51Eh) | (0h)           | (1h)           |              |
| 12.000           | 22.5792          | divide by 1         | 90.3168          | 7      | 0.5264  | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (007h) | (86C2h) | (0h)           | (1h)           |              |
| 12.000           | 24.576           | divide by 1         | 98.304           | 8      | 0.192   | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (008h) | (3127h) | (0h)           | (1h)           |              |
| 12.288           | 22.5792          | divide by 1         | 90.3168          | 7      | 0.35    | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (007h) | (599Ah) | (0h)           | (1h)           |              |
| 12.288           | 24.576           | divide by 1         | 98.304           | 8      | 0.0     | 1              | 4              | 0            |
| MHz              | MHz              | (0h)                | MHz              | (008h) | (0000h) | (0h)           | (1h)           |              |
| 13.000           | 22.5792          | divide by 1         | 90.3168          | 6      | 0.94745 | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (006h) | (F28Ch) | (0h)           | (1h)           |              |
| 13.000           | 24.576           | divide by 1         | 98.304           | 7      | 0.56185 | 1              | 4              | 1            |
| MHz              | MHz              | (0h)                | MHz              | (007h) | (8FD5h) | (0h)           | (1h)           |              |
| 19.200           | 22.5792          | divide by 2         | 90.3168          | 9      | 0.408   | 1              | 4              | 1            |
| MHz              | MHz              | (1h)                | MHz              | (009h) | (6873h) | (0h)           | (1h)           |              |
| 19.200           | 24.576           | divide by 2         | 98.304           | 10     | 0.24    | 1              | 4              | 1            |
| MHz              | MHz              | (1h)                | MHz              | (00Ah) | (3D71h) | (0h)           | (1h)           |              |
| 27.000           | 22.5792          | divide by 2         | 90.3168          | 6      | 0.69013 | 1              | 4              | 1            |
| MHz              | MHz              | (1h)                | MHz              | (006h) | (B0Adh) | (0h)           | (1h)           |              |
| 27.000           | 24.576           | divide by 2         | 98.304           | 7      | 0.28178 | 1              | 4              | 1            |
| MHz              | MHz              | (1h)                | MHz              | (007h) | (4823h) | (0h)           | (1h)           |              |

Table 56 Example FLL Settings



WM8946 Production Data

#### **VIDEO BUFFER**

The WM8946 provides a current mode output video buffer with an input 3<sup>rd</sup> order Butterworth low pass filter (LPF) and clamp. The video buffer is powered from LDOVDD – typically 3.3V. The video buffer is compatible with PAL and NTSC video formats.

The low pass filter (LPF) is intended to remove images in the video DAC output waveform at multiples of the DAC clock frequency. The input clamp supports AC coupling at the input to the video buffer.



Figure 33 Video Buffer Lowpass Filter Frequency Response Gain=0dB

The current mode output employed by the WM8946 video buffer allows operation at lower supply voltages than voltage mode video buffers. The current mode output also provides inherent protection against short circuits during jack insertion and removal. A current reference resistor (positioned close to the WM8946) ensures that the signal swing at the output of the buffer is the same as that at the receiving equipment (e.g. a television set), thus providing excellent signal reproduction.

For best performance, the input to the video buffer should be AC coupled and terminated to  $75\Omega$ . Note that the input clamp and pull-down features described below are only applicable to the AC-coupled input configuration.

Care should be taken with PCB layout, designing for at least 1GHz frequencies to avoid degrading performance. PCB vias and sharp corners should be avoided and parasitic capacitance minimised on signal paths; these should be kept as short and straight as possible. The LDOVDD supply should be decoupled as close to the WM8946 as possible. See the "External Components" section for more information.

The video buffer is enabled using the VB\_ENA register bit. The gain of the video buffer is selected using VB\_GAIN; this can be set to 0dB or 6dB (corresponding to 6dB or 12dB unloaded). The LPF response can be adjusted by setting the VB\_QBOOST register; this provides a small amount of additional gain in the region of the cut-off frequency.

The input signal clamp is enabled using VB\_CLAMP; this controls the DC component of the video signal for compatibility with the WM8941. The video buffer pull-down can be enabled using VB\_PD; this may be used during power-up of the video buffer in order to align the signal levels between the source and the WM8946. Note that the pull-down should not be enabled during normal operation of the video buffer; it should be enabled when the video buffer is first powered up, and subsequently disabled (e.g. After 20ms) once the circuit has settled.

A programmable DC offset can be applied to the output signal using the VB\_DISOFF register field; this can be set to 0mV, 20mV or 40mV offset.

Note that the VMID reference (see "Voltage References and Master Bias") must be enabled when using the WM8946 video buffer. VMID is enabled by setting VMID\_ENA, as defined in Table 41.



The video buffer control registers are described in Table 57.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                                                                                                                            |
|---------------------|-----|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------|
| R38 (26h)           | 7   | VB_ENA    | 0       | Video buffer enable                                                                                                                    |
| Video Buffer        |     |           |         | 0 = Disabled                                                                                                                           |
|                     |     |           |         | 1 = Enabled                                                                                                                            |
|                     | 6   | VB_QBOOST | 0       | Video buffer filter Q-Boost control                                                                                                    |
|                     |     |           |         | 0 = Disabled                                                                                                                           |
|                     |     |           |         | 1 = Enabled                                                                                                                            |
|                     | 5   | VB_GAIN   | 0       | Video buffer gain                                                                                                                      |
|                     |     |           |         | 0 = 0dB (=6dB unloaded)                                                                                                                |
|                     |     |           |         | 1 = 6dB (=12dB unloaded)                                                                                                               |
|                     | 4:3 | VB_DISOFF | 111     | Video buffer DC offset control                                                                                                         |
|                     |     |           |         | 000 = Reserved                                                                                                                         |
|                     |     |           |         | 001 = 40mV offset                                                                                                                      |
|                     |     |           |         | 010 = Reserved                                                                                                                         |
|                     |     |           |         | 011 = 20mV offset                                                                                                                      |
|                     |     |           |         | 100 = Reserved                                                                                                                         |
|                     |     |           |         | 101 = Reserved                                                                                                                         |
|                     |     |           |         | 110 = Reserved                                                                                                                         |
|                     |     |           |         | 111 = 0mV offset                                                                                                                       |
|                     |     |           |         | Note – the specified offset applies<br>to the 0dB gain setting<br>(VB_GAIN=0). When 6dB gain is<br>selected, the DC offset is doubled. |
|                     | 1   | VB_PD     | 0       | Video buffer pull-down                                                                                                                 |
|                     |     |           |         | 0 = pull-down disabled                                                                                                                 |
|                     |     |           |         | 1 = pull-down enabled                                                                                                                  |
|                     | 0   | VB_CLAMP  | 0       | Enable the clamp between the video input and ground                                                                                    |
|                     |     |           |         | 0 = no clamp                                                                                                                           |
|                     |     |           |         | 1 = Video buffer input is clamped to ground                                                                                            |

Table 57 Video Buffer Control

The video buffer circuit is illustrated in Figure 34.



Figure 34 Video Buffer Block Diagram

The video buffer requires two external resistor components, as illustrated in Figure 34. For best performance, the resistor  $R_{\text{SOURCE}}$  should be matched (equal) to the load impedance  $R_{\text{LOAD}}$ .



The resistance  $R_{REF}$  is a function of the circuit gain and a function of the parallel combination of  $R_{SOURCE}$  and  $R_{LOAD}$ . When  $VB\_GAIN = 0$  (0dB gain), the current gain of the video buffer is 5, as described by the equation  $I_{VBOUT} = 5 \times I_{VBREF}$ .

The resistor  $R_{\text{REF}}$  should be set equal to 5 x ( $R_{\text{SOURCE}}$  //  $R_{\text{LOAD}}$ ), where ( $R_{\text{SOURCE}}$  //  $R_{\text{LOAD}}$ ) is the effective resistance of the parallel combination of  $R_{\text{SOURCE}}$  and  $R_{\text{LOAD}}$ . (Note that the required resistance  $R_{\text{REF}}$  is the same for both settings of VB\_GAIN.)

In a typical application,  $R_{LOAD}$  = 75 $\Omega$ ,  $R_{SOURCE}$  = 75 $\Omega$ ,  $R_{REF}$  = 187 $\Omega$ .

### RECOMMENDED VIDEO BUFFER INITIALISATION SEQUENCE

Power Up (Video signal AC coupled to Video Buffer input):

| ACTION                                                                                                                                                                                                                    | LABEL                                                                              | REGISTER[BITS]                                                  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------|--|
| Turn on external supplies and wait for the supply voltages to settle.                                                                                                                                                     |                                                                                    |                                                                 |  |
| Reset registers to default state (software reset)                                                                                                                                                                         | SW_RESET                                                                           | R0 (00h) [15:0]                                                 |  |
| Enable VMID Fast Start and Start up<br>Bias<br>Select Start-Up Bias and set VMID soft<br>start for start-up ramp                                                                                                          | VMID_FAST_START = 1<br>STARTUP_BIAS_ENA = 1<br>BIAS_SRC = 1<br>VMID_RAMP[1:0] = 01 | R7 (07h) [11]<br>R7 (07h) [8]<br>R7 (07h) [7]<br>R7 (07h) [6:5] |  |
| If using VMID as the reference voltage for the LDO then select VMID fast start or set to 0 if using the Bandgap as the reference voltage for LDO.  Select LDO Start-Up Bias and enable LDO  Delay 300ms for LDO to settle | LDO_REF_SEL_FAST = 1<br>LDO_BIAS_SRC = 1<br>LDO_ENA = 1                            | R53 (35h) [14]<br>R53 (35h) [5]<br>R53 (35h) [15]               |  |
| Enable VMID Buffer and Master Bias<br>Set VMID_SEL[1:0] for fast start-up                                                                                                                                                 | BIAS_ENA = 1<br>VMID_BUF_ENA = 1<br>VMID_SEL[1:0] = 11                             | R2 (02h) [3]<br>R2 (02h) [2]<br>R2 (02h) [1:0]                  |  |
| Enable VMID Delay 150ms to allow VMID to settle                                                                                                                                                                           | VMID_ENA = 1                                                                       | R7 (07h) [4]                                                    |  |
| Set LDO for normal operation                                                                                                                                                                                              | LDO_REF_SEL_FAST = 0<br>LDO_BIAS_SRC = 0                                           | R53 (35h) [14]<br>R53 (35h) [5]                                 |  |
| Set VMID for normal operation                                                                                                                                                                                             | VMID_FAST_START = 0<br>STARTUP_BIAS_ENA = 0                                        | R7 (07h) [11]<br>R7 (07h) [8]                                   |  |
| Set VMID divider for normal operation                                                                                                                                                                                     | VMID_SEL = 01                                                                      | R2 (02h) [1:0]                                                  |  |
| Enable VMID Delay 150ms to allow VMID to settle                                                                                                                                                                           | VMID_ENA = 1                                                                       | R7 (07h) [4]                                                    |  |
| Set LDO for normal operation                                                                                                                                                                                              | LDO_REF_SEL_FAST = 0<br>LDO_BIAS_SRC = 0                                           | R53 (35h) [14]<br>R53 (35h) [5]                                 |  |
| Set Video Buffer Gain as required                                                                                                                                                                                         | VB_GAIN                                                                            | R38 (26h) [5]                                                   |  |
| Set Video Buffer Filter Q Boost as required                                                                                                                                                                               | VB_QBOOST                                                                          | R38 (26h) [6]                                                   |  |
| Enable Video Buffer Clamp                                                                                                                                                                                                 | VB_CLAMP = 1                                                                       | R38 (26h) [0]                                                   |  |
| Enable Video Buffer Pulldown                                                                                                                                                                                              | VB_PD = 1                                                                          | R38 (26h) [1]                                                   |  |
| Enable video buffer                                                                                                                                                                                                       | VB_ENA = 1                                                                         | R38 (26h) [7]                                                   |  |
| Delay 20ms for buffer to capture input level                                                                                                                                                                              |                                                                                    |                                                                 |  |
| Disable Video Buffer Pulldown                                                                                                                                                                                             | VB_PD = 0                                                                          | R38 (26h) [1]                                                   |  |



Power Up (Video signal DC coupled to Video Buffer input):

| ACTION                                                                                                                                                                                                                    | LABEL                                                                              | REGISTER[BITS]                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| Turn on external supplies and wait for the supply voltages to settle.                                                                                                                                                     |                                                                                    |                                                                 |
| Reset registers to default state (software reset)                                                                                                                                                                         | SW_RESET                                                                           | R0 (00h) [15:0]                                                 |
| Enable VMID Fast Start and Start up<br>Bias<br>Select Start-Up Bias and set VMID soft<br>start for start-up ramp                                                                                                          | VMID_FAST_START = 1<br>STARTUP_BIAS_ENA = 1<br>BIAS_SRC = 1<br>VMID_RAMP[1:0] = 01 | R7 (07h) [11]<br>R7 (07h) [8]<br>R7 (07h) [7]<br>R7 (07h) [6:5] |
| If using VMID as the reference voltage for the LDO then select VMID fast start or set to 0 if using the Bandgap as the reference voltage for LDO.  Select LDO Start-Up Bias and enable LDO  Delay 300ms for LDO to settle | LDO_REF_SEL_FAST = 1<br>LDO_BIAS_SRC = 1<br>LDO_ENA = 1                            | R53 (35h) [14]<br>R53 (35h) [5]<br>R53 (35h) [15]               |
| Enable VMID Buffer and Master Bias<br>Set VMID_SEL[1:0] for fast start-up                                                                                                                                                 | BIAS_ENA = 1<br>VMID_BUF_ENA = 1<br>VMID_SEL[1:0] = 11                             | R2 (02h) [3]<br>R2 (02h) [2]<br>R2 (02h) [1:0]                  |
| Enable VMID Delay 150ms to allow VMID to settle                                                                                                                                                                           | VMID_ENA = 1                                                                       | R7 (07h) [4]                                                    |
| Set LDO for normal operation                                                                                                                                                                                              | LDO_REF_SEL_FAST = 0<br>LDO_BIAS_SRC = 0                                           | R53 (35h) [14]<br>R53 (35h) [5]                                 |
| Set VMID for normal operation                                                                                                                                                                                             | VMID_FAST_START = 0<br>STARTUP_BIAS_ENA = 0                                        | R7 (07h) [11]<br>R7 (07h) [8]                                   |
| Set VMID divider for normal operation                                                                                                                                                                                     | VMID_SEL = 01                                                                      | R2 (02h) [1:0]                                                  |
| Set Video Buffer Gain as required                                                                                                                                                                                         | VB_GAIN                                                                            | R38 (26h) [5]                                                   |
| Set Video Buffer Filter Q Boost as required                                                                                                                                                                               | VB_QBOOST                                                                          | R38 (26h) [6]                                                   |
| Enable video buffer                                                                                                                                                                                                       | VB_ENA = 1                                                                         | R38 (26h) [7]                                                   |



#### **GENERAL PURPOSE INPUT/OUTPUT**

The WM8946 provides four multi-function pins which can be configured to provide a number of different functions. These are digital input/output pins on the DBVDD power domain. The GPIO pins are:

- GPIO1
- CS/GPIO2
- CIFMODE/GPIO3
- SDOUT/GPIO4

Note that only GPIO1 is a dedicated GPIO pin; the other pins are shared with Control Interface functions. The pins available for GPIO function depend on the selected Control Interface mode, as described in Table 58.

| CONTROL INTERFACE MODE |       | GPIO PIN A | /AILABILITY |       |
|------------------------|-------|------------|-------------|-------|
| 2-wire (I2C)           | GPIO1 | GPIO2      | GPIO3       | GPIO4 |
| 3-wire (SPI)           | GPIO1 |            | GPIO3       | GPIO4 |
| 4-wire (SPI)           | GPIO1 |            | GPIO3       |       |

Table 58 GPIO Pin Availability

Note that CIFMODE/GPIO3 pin selects between I2C and SPI Control Interface modes (see "Control Interface"). To enable GPIO functions on GPIO3, the MODE\_GPIO register bit must be set in order to disconnect this pin from the Control Interface circuit. Setting the MODE\_GPIO register bit causes the Control Interface mode selection to be latched; it will remain latched until a Software Reset or Power On Reset occurs.

The register fields that control the GPIO pins are described in Table 59.

For each GPIO, the selected function is determined by the GPn\_FN field, where n identifies the GPIO pin (1 to 4). The pin direction, set by GPn\_DIR, must be set according to function selected by GPn\_SEL.

When a pin is configured as a GPIO output, its level can be set to logic 0 or logic 1 using the GPn\_LVL field. When a pin is configured as a GPIO input, the logic level can be read from the respective GPn\_LVL bit. The GPIO output is inverted with respect to the GPn\_LVL register when the polarity bit GPn\_POL is set; the equivalent is true of GPIO inputs also.

Internal pull-up and pull-down resistors may be enabled using the GPn\_PULL fields; this allows greater flexibility to interface with different signals from other devices.

Each of the GPIO pins is an input to the Interrupt control circuit and can be used to trigger an Interrupt event. This may be configured as level-triggered or edge-triggered using the GPn\_FN registers. Edge detect raises an interrupt when the GPIO status changes; level detect asserts the interrupt for as long as the GPIO status is asserted. See "Interrupts".

An edge-triggered GPIO can be configured to trigger on a single edge or on both edges of the input signal; this is selected using the GPn\_INT\_MODE registers. A level-triggered or single-edge-triggered input may be configured using the GPn\_POL registers to respond to a high level/edge (when GPn\_POL = 0) or a low level/edge (when GPn\_POL = 1).

The GPIO control fields are defined in Table 59.



| REGISTER<br>ADDRESS           | BIT   | LABEL            | DEFAULT | DESCRIPTION                                                                                                                                                                                               |
|-------------------------------|-------|------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R11 (0Bh)<br>GPIO Config      | 0     | GPIO_MODE        | 0       | CIFMODE/GPIO3 pin configuration 0 = Pin configured as CIFMODE 1 = Pin configured as GPIO3 Note – when this bit is set to 1, it is latched and cannot be reset until Power-Off or Software Reset.          |
| R12 (0Ch)<br>GPIO1<br>Control | 15    | GP1_DIR          | 1       | GPIO1 Pin Direction  0 = Output  1 = Input                                                                                                                                                                |
|                               | 14:13 | GP1_PULL [1:0]   | 00      | GPIO1 pull-up / pull-down Enable  00 = no pull-up or pull-down  01 = pull-down  10 = pull-up  11 = reserved                                                                                               |
|                               | 12    | GP1_INT_MOD<br>E | 0       | GPIO1 Interrupt Mode  0 = GPIO interrupt is rising edge triggered (if GP1_POL=0) or falling edge triggered (if GP1_POL =1)  1 = GPIO interrupt is triggered on rising and falling edges                   |
|                               | 10    | GP1_POL          | 0       | GPIO1 Polarity Select 0 = Non-inverted 1 = Inverted                                                                                                                                                       |
|                               | 5     | GP1_LVL          | 0       | GPIO1 level. Write to this bit to set a GPIO output. Read from this bit to read GPIO input level.  When GP1_POL is set, the register contains the opposite logic level to the external pin.               |
|                               | 3:0   | GP1_FN [3:0]     | 0000    | GPIO1 Pin Function (see Table 60 for details)                                                                                                                                                             |
| R13 (0Dh)<br>GPIO2<br>Control | 15    | GP2_DIR          | 1       | GPIO2 Pin Direction 0 = Output 1 = Input                                                                                                                                                                  |
|                               | 14:13 | GP2_PULL [1:0]   | 00      | GPIO2 pull-up / pull-down Enable 00 = no pull-up or pull-down 01 = pull-down 10 = pull-up 11 = reserved                                                                                                   |
|                               | 12    | GP2_INT_MOD<br>E | 0       | GPIO2 Interrupt Mode  0 = GPIO interrupt is rising edge triggered (if GP2_POL=0) or falling edge triggered (if GP2_POL =1)  1 = GPIO interrupt is triggered on rising and falling edges                   |
|                               | 10    | GP2_POL          | 0       | GPIO2 Polarity Select<br>0 = Non-inverted<br>1 = Inverted                                                                                                                                                 |
|                               | 5     | GP2_LVL          | 0       | GPIO2 level. Write to this bit to set<br>a GPIO output. Read from this bit to<br>read GPIO input level.<br>When GP2_POL is set, the register<br>contains the opposite logic level to<br>the external pin. |
|                               | 3:0   | GP2_FN [3:0]     | 0000    | GPIO2 Pin Function<br>(see Table 60 for details)                                                                                                                                                          |



| REGISTER<br>ADDRESS | BIT   | LABEL          | DEFAULT | DESCRIPTION                                                                |
|---------------------|-------|----------------|---------|----------------------------------------------------------------------------|
| R14 (0Eh)           | 15    | GP3_DIR        | 1       | GPIO3 Pin Direction                                                        |
| GPIO3               | 10    | GI O_BIIX      | ,       | 0 = Output                                                                 |
| Control             |       |                |         | 1 = Input                                                                  |
|                     | 14:13 | GP3_PULL [1:0] | 10      | GPIO3 pull-up / pull-down Enable                                           |
|                     | 14.10 | 0. 0 022 [1.0] | 10      | 00 = no pull-up or pull-down                                               |
|                     |       |                |         | 01 = pull-down                                                             |
|                     |       |                |         | 10 = pull-up                                                               |
|                     |       |                |         | 11 = reserved                                                              |
|                     | 12    | GP3 INT MOD    | 0       | GPIO3 Interrupt Mode                                                       |
|                     | 12    | E              |         | 0 = GPIO interrupt is rising edge                                          |
|                     |       |                |         | triggered (if GP3_POL=0) or falling                                        |
|                     |       |                |         | edge triggered (if GP3_POL =1)                                             |
|                     |       |                |         | 1 = GPIO interrupt is triggered on                                         |
|                     |       |                |         | rising and falling edges                                                   |
|                     | 10    | GP3_POL        | 0       | GPIO3 Polarity Select                                                      |
|                     |       |                |         | 0 = Non-inverted                                                           |
|                     |       |                |         | 1 = Inverted                                                               |
|                     | 5     | GP3_LVL        | 0       | GPIO3 level. Write to this bit to set                                      |
|                     |       |                |         | a GPIO output. Read from this bit to                                       |
|                     |       |                |         | read GPIO input level.                                                     |
|                     |       |                |         | When GP3_POL is set, the register contains the opposite logic level to     |
|                     |       |                |         | the external pin.                                                          |
|                     | 3:0   | GP3 FN [3:0]   | 0000    | GPIO3 Pin Function                                                         |
|                     |       |                |         | (see Table 60 for details)                                                 |
| R15 (0Fh)           | 15    | GP4_DIR        | 1       | GPIO4 Pin Direction                                                        |
| GPIO4               |       | _              |         | 0 = Output                                                                 |
| Control             |       |                |         | 1 = Input                                                                  |
|                     | 14:13 | GP4_PULL [1:0] | 00      | GPIO4 pull-up / pull-down Enable                                           |
|                     |       |                |         | 00 = no pull-up or pull-down                                               |
|                     |       |                |         | 01 = pull-down                                                             |
|                     |       |                |         | 10 = pull-up                                                               |
|                     |       |                |         | 11 = reserved                                                              |
|                     | 12    | GP4_INT_MOD    | 0       | GPIO4 Interrupt Mode                                                       |
|                     |       | E              |         | 0 = GPIO interrupt is rising edge                                          |
|                     |       |                |         | triggered (if GP4_POL=0) or falling                                        |
|                     |       |                |         | edge triggered (if GP4_POL =1)                                             |
|                     |       |                |         | 1 = GPIO interrupt is triggered on                                         |
|                     | 40    | 004 001        | •       | rising and falling edges                                                   |
|                     | 10    | GP4_POL        | 0       | GPIO4 Polarity Select                                                      |
|                     |       |                |         | 0 = Non-inverted                                                           |
|                     | F     | CD4 LV         |         | 1 = Inverted                                                               |
|                     | 5     | GP4_LVL        | 0       | GPIO4 level. Write to this bit to set a GPIO output. Read from this bit to |
|                     |       |                |         | read GPIO input level.                                                     |
|                     |       |                |         | When GP4_POL is set, the register                                          |
|                     |       |                |         | contains the opposite logic level to                                       |
|                     |       |                |         | the external pin.                                                          |
|                     | 3:0   | GP4_FN [3:0]   | 0000    | GPIO4 Pin Function                                                         |
|                     |       | i              | •       | (see Table 60 for details)                                                 |

Table 59 GPIO Control



#### **GPIO FUNCTION SELECT**

The available GPIO functions are described in Table 60. The function of each GPIO is set using the GPn\_FN register, where n identifies the GPIO pin (1 to 4).

Note that the polarity of the GPIO inputs and outputs may be selected using the GPn\_POL register bits. When GPn\_POL = 1, then the polarity is inverted with respect to the descriptions below.

The GPIO input functions may be used to detect headphone jack insertion or a button press. These signals may be used as inputs to the Interrupt Controller, via the integrated de-bounce circuit.

| GPn_FN | DESCRIPTION             | COMMENTS                                                                                                       |
|--------|-------------------------|----------------------------------------------------------------------------------------------------------------|
| 0000   | Logic level input       | External logic level is read from GPn_LVL.                                                                     |
|        |                         | Associated interrupt (when enabled) is level-triggered.                                                        |
| 0001   | Edge detection input    | External logic level is read from GPn_LVL.                                                                     |
|        |                         | Associated interrupt (when enabled) is edge triggered. Note that TOCLK_ENA must be set.                        |
| 0010   | CLKOUT output           | Output clock frequency is set by CLKOUT_DIV.                                                                   |
| 0011   | Interrupt (IRQ) output  | Hardware output of all unmasked Interrupts.                                                                    |
| 0100   | Reserved                |                                                                                                                |
| 0101   | Reserved                |                                                                                                                |
| 0110   | Reserved                |                                                                                                                |
| 0111   | Temperature flag output | Indicates the temperature sensor output. This is a hardware output of the TEMP_STS bit (assuming GPn_POL = 0). |
|        |                         | 0 = Normal                                                                                                     |
|        |                         | 1 = Overtemperature                                                                                            |
| 1000   | Reserved                |                                                                                                                |
| 1001   | DMICCLK output          | Output clock for digital microphone interface                                                                  |
| 1010   | Logic level output      | Pin logic level is set by GPn_LVL.                                                                             |
| 1011   | LDO_UV output           | Indicates the LDO undervoltage status. This is a hardware output of the LDO_UV_STS bit (assuming GPn_POL = 0). |
|        |                         | 0 = Normal                                                                                                     |
|        |                         | 1 = LDO undervoltage                                                                                           |
| 1100   | Reserved                |                                                                                                                |
| 1101   | Reserved                |                                                                                                                |
| 1110   | Reserved                |                                                                                                                |
| 1111   | Reserved                |                                                                                                                |

Table 60 GPIO Function Select

### **INTERRUPTS**

The Interrupt Controller has multiple inputs. These include the GPIO input pins, Temperature sensor and the LDO Regulator. Any combination of these inputs can be used to trigger an Interrupt (IRQ) event.

There is an Interrupt Status field associated with each of the IRQ inputs. These are listed within the System Interrupts Register (R16), as described in Table 61. The status of the IRQ inputs can be read at any time from this register or else in response to the Interrupt (IRQ) output being signalled via a GPIO pin.

Individual mask bits can select or deselect different functions from the Interrupt controller. These are listed within the System Interrupts Mask Register (R19), as described in Table 61. Note that the status fields remain valid, even when masked, but the masked bits will not cause the Interrupt (IRQ) output to be asserted.

The Interrupt (IRQ) output represents the logical 'OR' of all the unmasked IRQ inputs. The bits within the System Interrupts Register (R16) are latching fields and, once they are set, they are not reset until the System Interrupts Register is read. Accordingly, the Interrupt (IRQ) output is not reset until the System Interrupts Register has been read. Note that, if the condition that caused the IRQ input to be asserted is still valid, then the Interrupt (IRQ) output will remain set even after the System Interrupts Register has been read.

When GPIO input is used to trigger an Interrupt event, polarity can be set using the GPn\_POL bits as described in Table 59. This allows the IRQ event to be used to indicate a rising or a falling edge of the external logic signal. If desired, the GPn\_INT\_MODE bits can be used to select an Interrupt event on both the rising and falling edges.

The GPIO inputs to the Interrupt Controller are de-bounced to avoid false detections. The timeout clock (TOCLK) is required for this function. When using GPIO inputs to the Interrupt Controller, the TOCLK must be enabled by setting the TOCLK\_ENA and OSC\_CLK\_ENA bits as described in "Clocking and Sample Rates".

The Interrupt (IRQ) output can be globally masked by setting the IM\_IRQ register. The Interrupt is masked by default.

The Interrupt (IRQ) output may be configured on any of the GPIO pins. See "General Purpose Input / Output" for details of how to configure GPIO pins for Interrupt (IRQ) output.

The Interrupt control fields are defined in Table 61.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                            |
|---------------------|-----|----------|---------|------------------------------------------------------------------------|
| R16 (10h)           | 15  | TEMP_INT | 0       | Thermal Interrupt status                                               |
| System              |     |          |         | 0 = Thermal interrupt not set                                          |
| Interrupts          |     |          |         | 1 = Thermal interrupt set                                              |
|                     |     |          |         | This bit is latched when set; it is cleared when the register is Read. |
|                     | 14  | GP4_INT  | 0       | GPIO4 Interrupt status                                                 |
|                     |     |          |         | 0 = GPIO4 interrupt not set                                            |
|                     |     |          |         | 1 = GPIO4 interrupt set                                                |
|                     |     |          |         | This bit is latched when set; it is cleared when the register is Read. |
|                     | 13  | GP3_INT  | 0       | GPIO3 Interrupt status                                                 |
|                     |     |          |         | 0 = GPIO3 interrupt not set                                            |
|                     |     |          |         | 1 = GPIO3 interrupt set                                                |
|                     |     |          |         | This bit is latched when set; it is cleared when the register is Read. |
|                     | 12  | GP2_INT  | 0       | GPIO2 Interrupt status                                                 |
|                     |     |          |         | 0 = GPIO2 interrupt not set                                            |
|                     |     |          |         | 1 = GPIO2 interrupt set                                                |
|                     |     |          |         | This bit is latched when set; it is                                    |
|                     |     |          |         | cleared when the register is Read.                                     |



| REGISTER<br>ADDRESS | BIT | LABEL             | DEFAULT | DESCRIPTION                                                            |
|---------------------|-----|-------------------|---------|------------------------------------------------------------------------|
|                     | 11  | GP1_INT           | 0       | GPIO1 Interrupt status                                                 |
|                     |     |                   |         | 0 = GPIO1 interrupt not set                                            |
|                     |     |                   |         | 1 = GPIO1 interrupt set                                                |
|                     |     |                   |         | This bit is latched when set; it is cleared when the register is Read. |
|                     | 0   | LDO_UV_INT        | 0       | LDO Undervoltage Interrupt                                             |
|                     |     |                   |         | 0 = LDO Undervoltage interrupt not set                                 |
|                     |     |                   |         | 1 = LDO Undervoltage interrupt set                                     |
|                     |     |                   |         | This bit is latched when set; it is cleared when the register is Read. |
| R18 (12h)           | 0   | IM_IRQ            | 1       | IRQ (GPIO output) Mask                                                 |
| IRQ Config          |     |                   |         | 0 = Normal                                                             |
|                     |     |                   |         | 1 = IRQ output is masked                                               |
| R19 (13h)           | 15  | IM_TEMP_INT       | 0       | Interrupt mask for thermal status                                      |
| System              |     |                   |         | 0 = Not masked                                                         |
| Interrupts          |     |                   |         | 1 = Masked                                                             |
| Mask                | 14  | IM_GP4_INT        | 0       | Interrupt mask for GPIO4                                               |
|                     |     |                   |         | 0 = Not masked                                                         |
|                     |     |                   |         | 1 = Masked                                                             |
|                     | 13  | IM_GP3_INT        | 0       | Interrupt mask for GPIO3                                               |
|                     |     |                   |         | 0 = Not masked                                                         |
|                     |     |                   |         | 1 = Masked                                                             |
|                     | 12  | IM_GP2_INT        | 0       | Interrupt mask for GPIO2                                               |
|                     |     |                   |         | 0 = Not masked                                                         |
|                     |     |                   |         | 1 = Masked                                                             |
|                     | 11  | IM_GP1_INT        | 0       | Interrupt mask for GPIO1                                               |
|                     |     |                   |         | 0 = Not masked                                                         |
|                     |     |                   |         | 1 = Masked                                                             |
|                     | 0   | IM_LDO_UV_IN<br>T | 0       | Interrupt mask for LDO Undervoltage status                             |
|                     |     |                   |         | 0 = Not masked                                                         |
|                     |     |                   |         | 1 = Masked                                                             |

**Table 61 Interrupt Control** 

WM8946 Production Data

### **CONTROL INTERFACE**

The WM8946 is controlled by writing to its control registers. Readback is available for all registers. The Control Interface can operate as either a 2-, 3- or 4-wire interface:

- 2-wire (I2C) mode uses pins SCLK and SDA
- 3-wire (SPI) mode uses pins CS, SCLK and SDA
- 4-wire (SPI) mode uses pins CS, SCLK, SDA and SDOUT

Readback is provided on the bi-directional pin SDA in 2-/3-wire modes.

The device address in 2-wire (I2C) mode is 34h.

The WM8946 uses 15-bit register addresses and 16-bit data in all Control Interface modes.

#### SELECTION OF CONTROL INTERFACE MODE

The WM8946 Control Interface can be configured for I2C mode or SPI modes using the CIFMODE/GPIO3 pin at power-up. The mode selection is as described in Table 63.

| CIFMODE/GPIO3 | INTERFACE FORMAT |  |
|---------------|------------------|--|
| Low           | 2 wire           |  |
| High          | 3- or 4- wire    |  |

**Table 62 Control Interface Mode Selection** 

After the Control Interface Mode has been configured, the MODE\_GPIO register bit should be set in order to latch the selection and to allow GPIO functions to be supported on the CIFMODE/GPIO3 pin. After the MODE\_GPIO register bit has been set, the Control Interface mode selection will remain latched until a Software Reset or Power On Reset occurs. See "General Purpose Input / Output" for details.

In 2-wire (I2C) Control Interface mode, Auto-Increment mode may be selected. This enables multiple write and multiple read operations to be scheduled faster than is possible with single register operations. The auto-increment option is enabled when the AUTO\_INC register bit is set. This bit is defined in Table 63. Auto-increment is disabled by default.

In SPI modes, 3-wire or 4-wire operation may be selected using the SPI\_4WIRE register bit. In 3-wire mode, register readback is provided using the bi-directional pin SDA. In 4-wire mode, register readback is provided using SDOUT. The SDOUT pin may be configured as CMOS or as Open Drain using the SPI\_OD bit. In 3-wire mode the SDA pin may be configured as CMOS or as Open Drain using the SPI\_OD bit. If the open drain option is selected (SPI\_OD = 1) then an external pull-up resistor is required on the SDOUT or SDA output pin.

The Control Interface configuration bits are described in Table 63.

| REGISTER<br>ADDRESS  | BIT | LABEL     | DEFAULT | DESCRIPTION                              |
|----------------------|-----|-----------|---------|------------------------------------------|
| t(14h)               | 2   | SPI_OD    | 0       | SDOUT pin configuration                  |
| Control<br>Interface |     |           |         | (applies to 3-wire and 4-wire mode only) |
|                      |     |           |         | 0 = SDOUT output is CMOS                 |
|                      |     |           |         | 1 = SDOUT output is open drain           |
|                      | 1   | SPI_4WIRE | 1       | SPI control mode select                  |
|                      |     |           |         | 0 = 3-wire using bidirectional SDA       |
|                      |     |           |         | 1 = 4-wire using SDOUT                   |
|                      | 0   | AUTO_INC  | 0       | Enables address auto-increment           |
|                      |     |           |         | (applies to 2-wire / I2C mode only)      |
|                      |     |           |         | 0 = Disabled                             |
|                      |     |           |         | 1 = Enabled                              |

**Table 63 Control Interface Configuration** 



#### 2-WIRE (I2C) CONTROL MODE

In 2-wire mode, the WM8946 is a slave device on the control interface; SCLK is a clock input, while SDA is a bi-directional data pin. To allow arbitration of multiple slaves (and/or multiple masters) on the same interface, the WM8946 transmits logic 1 by tri-stating the SDA pin, rather than pulling it high. An external pull-up resistor is required to pull the SDA line high so that the logic 1 can be recognised by the master.

In order to allow many devices to share a single 2-wire control bus, every device on the bus has a unique 7-bit device ID (this is not the same as the 15-bit address of each register in the WM8946). The WM8946 device ID is 34h. The LSB of the device ID is the Read/Write bit; this bit is set to logic 1 for "Read" and logic 0 for "Write".

The WM8946 operates as a slave device only. The controller indicates the start of data transfer with a high to low transition on SDA while SCLK remains high. This indicates that a device ID, register address and data will follow. The WM8946 responds to the start condition and shifts in the next eight bits on SDA (7-bit device ID + Read/Write bit, MSB first). If the device ID received matches the device ID of the WM8946, then the WM8946 responds by pulling SDA low on the next clock pulse (ACK). If the device ID is not recognised or the R/W bit is '1' when operating in write only mode, the WM8946 returns to the idle condition and waits for a new start condition and valid address.

If the device ID matches the device ID of the WM8946, the data transfer continues as described below. The controller indicates the end of data transfer with a low to high transition on SDA while SCLK remains high. After receiving a complete address and data sequence the WM8946 returns to the idle state and waits for another start condition. If a start or stop condition is detected out of sequence at any point during data transfer (i.e. SDA changes while SCLK is high), the device returns to the idle condition.

The WM8946 supports the following read and write operations:

- Single write
- Single read
- Multiple write using auto-increment
- Multiple read using auto-increment

The sequence of signals associated with a single register write operation is illustrated in Figure 35.



Figure 35 Control Interface 2-wire (I2C) Register Write

WM8946 Production Data

The sequence of signals associated with a single register read operation is illustrated in Figure 36.



Figure 36 Control Interface 2-wire (I2C) Register Read

The Control Interface also supports other register operations, as listed above. The interface protocol for these operations is summarised below. The terminology used in the following figures is detailed in Table 64.

Note that, for multiple write and multiple read operations, the auto-increment option must be enabled. This feature is enabled by default, as noted in Table 63.

| TERMINOLOGY   | DESCRIPTION                         |  |  |  |
|---------------|-------------------------------------|--|--|--|
| S             | Start Condition                     |  |  |  |
| Sr            | Repeated start                      |  |  |  |
| A             | Acknowledge                         |  |  |  |
| Р             | Stop Condition                      |  |  |  |
| R/W           | ReadNotWrite 0 = Write              |  |  |  |
|               | 1 = Read                            |  |  |  |
| [White field] | Data flow from bus master to WM8946 |  |  |  |
| [Grey field]  | Data flow from WM8946 to bus master |  |  |  |

**Table 64 Control Interface Terminology** 



Figure 37 Single Register Write to Specified Address



Figure 38 Single Register Read from Specified Address



Figure 39 Multiple Register Write to Specified Address using Auto-increment



Figure 40 Multiple Register Read from Specified Address using Auto-increment



Figure 41 Multiple Register Read from Last Address using Auto-increment

Multiple Write and Multiple Read operations enable the host processor to access sequential blocks of the data in the WM8946 register map faster than is possible with single register operations. The auto-increment option is enabled when the AUTO\_INC register bit is set. This bit is defined in Table 63. Auto-increment is disabled by default.

### 3-WIRE (SPI) CONTROL MODE

The 3-wire control interface uses the  $\overline{CS}$ , SCLK and SDA pins.

In 3-wire control mode, a control word consists of 32 bits. The first bit is the read/write bit (R/W), which is followed by 15 address bits (A14 to A0) that determine which control register is accessed. The remaining 16 bits (B15 to B0) are data bits, corresponding to the 16 bits in each control register.

In 3-wire mode, every rising edge of SCLK clocks in one data bit from the SDA pin. The data is latched on the 32<sup>nd</sup> falling edge of SCLK after 32 bits of data have been clocked into the device.

In Write operations (R/W=0), all SDA bits are driven by the controlling device.

In Read operations (R/W=1), the SDA pin is driven by the controlling device to clock in the register address, after which the WM8946 drives the SDA pin to output the applicable data bits.

Similarly to 2-wire control mode, the WM8946 can be set to transmit logic 1 by tri-stating the SDA pin, rather than pulling it high (SPI\_OD = 1). An external pull-up resistor is required to pull the SDA line high so that the logic 1 can be recognised by the master.

The 3-wire control mode timing is illustrated in Figure 42.



WM8946 Production Data



Figure 42 3-Wire Serial Control Interface

### 4-WIRE (SPI) CONTROL MODE

The 4-wire control interface uses the  $\overline{CS}$ , SCLK, SDA and SDOUT pins.

The Data Output pin, SDOUT, can be configured as CMOS or Open Drain, as described in Table 63. In CMOS mode, SDOUT is driven low when not outputting register data bits. In Open Drain mode, SDOUT is undriven (high impedance) when not outputting register data bits.

In Write operations (R/W=0), this mode is the same as 3-wire mode described above.

In Read operations (R/W=1), the SDATA pin is ignored following receipt of the valid register address. SDOUT is driven by the WM8946.

The 4-wire control mode timing is illustrated in Figure 43 and Figure 44.



Figure 43 4-Wire Readback (CMOS)



Figure 44 4-Wire Readback (Open Drain)



## **POWER MANAGEMENT**

The WM8946 has two control registers that allow users to select which functions are active. For minimum power consumption, unused functions should be disabled. To minimise pop or click noise, it is important to enable or disable these functions in the correct order, and to use the signal mute registers as part of a carefully structured control sequence. Refer to the "Recommended Power Up/Down Sequence" section for more details.

The power management control registers are described in Table 65.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                           |  |  |  |  |  |
|---------------------|-----|-------------|---------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| R2 (02h)            | 13  | INPPGAR_ENA | 0       | Right Input PGA Enable                                                                                |  |  |  |  |  |
| Power               |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
| management          |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
| 1                   | 12  | INPPGAL_ENA | 0       | Left Input PGA Enable                                                                                 |  |  |  |  |  |
|                     |     | _           |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     | 11  | ADCR_ENA    | 0       | Right ADC and Record filter Enable                                                                    |  |  |  |  |  |
|                     |     | _           |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     |     |             |         | ADCR_ENA must be set to 1 when processing right channel data from the ADC or Digital Microphone.      |  |  |  |  |  |
|                     | 10  | ADCL_ENA    | 0       | Left ADC and Record filter Enable                                                                     |  |  |  |  |  |
|                     |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     |     |             |         | ADCL_ENA must be set to 1 when processing left channel data from the ADC or Digital Microphone.       |  |  |  |  |  |
|                     | 4   | MICB_ENA    | 0       | Microphone Bias Enable                                                                                |  |  |  |  |  |
|                     |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     | 3   | BIAS_ENA    | 0       | Master Bias Enable                                                                                    |  |  |  |  |  |
|                     |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
| R3 (03h)            | 15  | OUTR_ENA    | 0       | LINEOUTR enable                                                                                       |  |  |  |  |  |
| Power               |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
| management<br>2     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
| 2                   | 14  | OUTL_ENA    | 0       | LINEOUTL enable                                                                                       |  |  |  |  |  |
|                     |     |             |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     | 13  | SPKR_PGA_EN | 0       | Speaker Right PGA enable                                                                              |  |  |  |  |  |
|                     |     | Α           |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     | 12  | SPKL_PGA_EN | 0       | Speaker Left PGA enable                                                                               |  |  |  |  |  |
|                     |     | A           |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     | 11  | SPKR_SPKVDD | 0       | SPKOUTR enable                                                                                        |  |  |  |  |  |
|                     |     | _ENA        |         | 0 = Disabled                                                                                          |  |  |  |  |  |
|                     |     |             |         | 1 = Enabled                                                                                           |  |  |  |  |  |
|                     |     |             |         | Note that SPKOUTR is also                                                                             |  |  |  |  |  |
|                     |     |             |         | controlled by SPKR_OP_ENA. When powering down SPKOUTR, the SPKR_SPKVDD_ENA bit should be reset first. |  |  |  |  |  |



| REGISTER<br>ADDRESS | BIT | LABEL               | DEFAULT | DESCRIPTION                                                                                                                                                                  |
|---------------------|-----|---------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 10  | SPKL_SPKVDD<br>_ENA | 0       | SPKOUTL enable 0 = Disabled 1 = Enabled Note that SPKOUTL is also controlled by SPKL_OP_ENA. When powering down SPKOUTL, the SPKL_SPKVDD_ENA bit should be reset first       |
|                     | 7   | SPKR_OP_ENA         | 0       | SPKOUTR enable  0 = Disabled  1 = Enabled  Note that SPKOUTR is also controlled by  SPKR_SPKVDD_ENA. When powering up SPKOUTR, the  SPKR_OP_ENA bit should be enabled first. |
|                     | 6   | SPKL_OP_ENA         | 0       | SPKOUTL enable  0 = Disabled  1 = Enabled  Note that SPKOUTL is also controlled by SPKL_SPKVDD_ENA.  When powering up SPKOUTL, the SPKL_OP_ENA bit should be enabled first   |
|                     | 3   | SPKR_MIX_EN<br>A    | 0       | Right speaker output mixer enable 0 = Disabled 1 = Enabled                                                                                                                   |
|                     | 2   | SPKL_MIX_ENA        | 0       | Left speaker output mixer enable 0 = Disabled 1 = Enabled                                                                                                                    |
|                     | 1   | DACR_ENA            | 0       | Right DAC Enable 0 = Disabled 1 = Enabled DACR_ENA must be set to 1 when processing right channel data from the DAC or Digital Beep Generator.                               |
|                     | 0   | DACL_ENA            | 0       | Left DAC Enable  0 = Disabled  1 = Enabled  DACR_ENA must be set to 1 when processing left channel data from the DAC or Digital Beep Generator.                              |

Table 65 Power Management Control

### THERMAL SHUTDOWN

The WM8946 incorporates a temperature sensor which detects when the device temperature is within normal limits. The temperature status can be read at any time from the TEMP\_STS bit, as described in Table 66. This bit can be polled at any time, or may output directly on a GPIO pin, or may be used to generate Interrupt events.

The temperature sensor can be configured to shut down the speaker outputs in the event of an overtemperature condition. This is configured using the THERR\_ACT register field.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                                                                                          |  |  |  |
|---------------------|-----|-----------|---------|------------------------------------------------------------------------------------------------------|--|--|--|
| R17 (11h)           | 15  | TEMP_STS  | 0       | Thermal Sensor status                                                                                |  |  |  |
| Status Flags        |     |           |         | 0 = Normal                                                                                           |  |  |  |
|                     |     |           |         | 1 = Overtemperature                                                                                  |  |  |  |
| R42 (2Ah)           | 15  | THERR_ACT | 1       | Thermal Shutdown enable                                                                              |  |  |  |
| Output ctrl         |     |           |         | 0 = Disabled                                                                                         |  |  |  |
|                     |     |           |         | 1 = Enabled                                                                                          |  |  |  |
|                     |     |           |         | When THERR_ACT = 1, then an overtemperature condition will cause the speaker outputs to be disabled. |  |  |  |

**Table 66 Thermal Shutdown Control** 

#### **POWER ON RESET**

The WM8946 includes a Power-On Reset (POR) circuit, which is used to reset the digital logic into a default state after power up. The POR circuit derives its output from LDOVDD and DCVDD. The internal POR signal is asserted low when either LDOVDD or DCVDD are below minimum thresholds.

The specific behaviour of the circuit will vary, depending on relative timing of the supply voltages. Typical scenarios are illustrated in Figure 45 and Figure 46.



Figure 45 Power On Reset Timing - LDOVDD Enabled First



Figure 46 Power On Reset Timing - DCVDD Enabled First

The  $\overline{POR}$  signal is undefined until LDOVDD has exceeded the minimum threshold,  $V_{pora}$  Once this threshold has been exceeded,  $\overline{POR}$  is asserted low and the chip is held in reset. In this condition, all writes to the control interface are ignored. Once LDOVDD and DCVDD have both reached their respective power on thresholds,  $\overline{POR}$  is released high, all registers are in their default state, and writes to the control interface may take place.

Note that a minimum power-on reset period,  $T_{POR}$ , applies even if LDOVDD and DCVDD have zero rise time. (This specification is guaranteed by design rather than test.)

On power down, POR is asserted low when LDOVDD or DCVDD falls below their respective power-down thresholds.

| Typical Power-On Reset  | parameters for the WM8946   | are defined in Table 67  |
|-------------------------|-----------------------------|--------------------------|
| Typical Lower-Off Neset | parameters for the willogat | are defined in Table 01. |

| SYMBOL           | DESCRIPTION                           | MIN | TYP  | MAX | UNIT |
|------------------|---------------------------------------|-----|------|-----|------|
| $V_{pora}$       | Power-On undefined threshold (LDOVDD) |     | 0.5  |     | V    |
| $V_{pora\_on}$   | Power-On threshold (LDOVDD)           |     | 1.15 |     | V    |
| $V_{pora\_off}$  | Power-Off threshold (LDOVDD)          |     | 1.12 |     | V    |
| $V_{pord\_on}$   | Power-On threshold (DCVDD)            |     | 0.57 |     | V    |
| $V_{pord\_off}$  | Power-Off threshold (DCVDD)           |     | 0.56 |     | V    |
| T <sub>POR</sub> | Minimum Power-On Reset period         |     | 10.6 |     | μS   |

Table 67 Typical Power-On Reset Parameters

Separate Power-On Reset circuits are also implemented on the DBVDD and SPKVDD domains. These circuits ensure correct device behaviour whenever these supplies are enabled or disabled.

# **SOFTWARE RESET AND DEVICE ID**

The WM8946 can be reset by writing to Register R0. This is a read-only register, and the contents of R0 will not be affected by writing to this Register.

The Device ID can be read back from Register R0. The Chip Revision ID can be read back from Register 1, as described in Table 68.

| REGISTER<br>ADDRESS            | BIT  | LABEL              | DEFAULT | DESCRIPTION                                                           |
|--------------------------------|------|--------------------|---------|-----------------------------------------------------------------------|
| R0 (00h)<br>Software           | 15:0 | SW_RESET<br>[15:0] | 6229h   | Writing to this register resets all registers to their default state. |
| Reset/Chip<br>ID 1             |      |                    |         | Reading from this register will indicate device family ID 6229h.      |
| R1 (01h)<br>Revision<br>Number | 3:0  | CHIP_REV [3:0]     |         | Reading from this register will indicate the Revision ID.             |

Table 68 Chip Reset and ID



# RECOMMENDED POWER UP / POWER-DOWN SEQUENCES

In order to minimise output pop and click noise, it is recommended that the WM8946 device is powered-up and powered-down using the control sequences described in Table 69 and Table 70 respectively.

The power-up sequence described here includes enabling the DACs and output drivers; note that additional configuration will be required to enable the required internal signal paths.

The sequences noted here are provided as guidance only; each sequence will require to be adjusted to the particular application requirements.

| DESCRIPTION                                                                                                                                                                                                               | LABEL                                                                                       | REGISTER [BITS]                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| Turn on external supplies and wait for the supply voltages to settle.                                                                                                                                                     |                                                                                             |                                                                                                  |
| Reset registers to default state (software reset)                                                                                                                                                                         | SW_RESET                                                                                    | R0 (00h) [15:0]                                                                                  |
| Enable speaker and line discharge bits                                                                                                                                                                                    | SPKR_DISCH = 1 SPKL_DISCH = 1 LINER_DISCH = 1 LINEL_DISCH = 1                               | R42 (2Ah) [7]<br>R42 (2Ah) [6]<br>R42 (2Ah) [5]<br>R42 (2Ah) [4]                                 |
| Enable VMID to speaker and line outputs                                                                                                                                                                                   | SPKR_VMID_OP_ENA = 1 SPKL_VMID_OP_ENA = 1 LINER_VMID_OP_ENA = 1 LINEL_VMID_OP_ENA = 1       | R42 (2Ah) [13]<br>R42 (2Ah) [12]<br>R42 (2Ah) [11]<br>R42 (2Ah) [10]                             |
| Enable VMID Fast Start and Start up Bias<br>Select Start-Up Bias and set VMID soft start for start-up ramp                                                                                                                | VMID_FAST_START = 1<br>STARTUP_BIAS_ENA = 1<br>BIAS_SRC = 1<br>VMID_RAMP[1:0] = 01          | R7 (07h) [11]<br>R7 (07h) [8]<br>R7 (07h) [7]<br>R7 (07h) [6:5]                                  |
| If using VMID as the reference voltage for the LDO then select VMID fast start or set to 0 if using the Bandgap as the reference voltage for LDO.  Select LDO Start-Up Bias and enable LDO  Delay 300ms for LDO to settle | LDO_REF_SEL_FAST = 1<br>LDO_BIAS_SRC = 1<br>LDO_ENA = 1                                     | R53 (35h) [14] R53<br>(35h) [5]<br>R53 (35h) [15]                                                |
| Enable VMID Buffer and Master Bias<br>Set VMID_SEL[1:0] for fast start-up                                                                                                                                                 | BIAS_ENA = 1 VMID_BUF_ENA = 1<br>VMID_SEL[1:0] = 11                                         | R2 (02h) [3] R2<br>(02h) [2]<br>R2 (02h) [1:0]                                                   |
| Disable speaker and line discharge bits                                                                                                                                                                                   | SPKP_DISCH = 0 SPKN_DISCH = 0 LINER_DISCH = 0 LINEL_DISCH = 0                               | R42 (2Ah) [6]<br>R42 (2Ah) [7]<br>R42 (2Ah) [5]<br>R42 (2Ah) [4]                                 |
| Enable speaker mixer and DAC                                                                                                                                                                                              | SPKR_MIX_ENA = 1 SPKL_MIX_ENA = 1 DACR_ENA = 1 DACL_ENA = 1                                 | R3 (03h) [3]<br>R3 (03h) [2]<br>R3 (03h) [1]<br>R3 (03h) [0]                                     |
| Enable speaker outputs and speaker PGA and lineout output as required                                                                                                                                                     | OUTR_ENA = 1 OUTL_ENA = 1 SPKR_PGA_ENA = 1 SPKL_PGA_ENA = 1 SPKN_OP_ENA = 1 SPKP_OP_ENA = 1 | R3 (03h) [15]<br>R3 (03h) [14]<br>R3 (03h) [13]<br>R3 (03h) [12]<br>R3 (03h) [7]<br>R3 (03h) [6] |
| Enable power to speaker drive                                                                                                                                                                                             | SPKR_SPKVDD_ENA = 1<br>SPKL_ SPKVDD _ENA = 1                                                | R3 (03h) [11]<br>R3 (03h) [10]                                                                   |
| Enable VMID Delay 150ms to allow VMID to settle                                                                                                                                                                           | VMID_ENA = 1                                                                                | R7 (07h) [4]                                                                                     |
| Set LDO for normal operation                                                                                                                                                                                              | LDO_REF_SEL_FAST = 0                                                                        | R53 (35h) [14]                                                                                   |



Production Data \_\_\_\_\_\_ **WM8946** 

| DESCRIPTION                           | LABEL                                       | REGISTER [BITS]               |  |  |
|---------------------------------------|---------------------------------------------|-------------------------------|--|--|
|                                       | LDO_BIAS_SRC = 0                            | R53 (35h) [5]                 |  |  |
| Set VMID for normal operation         | VMID_FAST_START = 0<br>STARTUP_BIAS_ENA = 0 | R7 (07h) [11]<br>R7 (07h) [8] |  |  |
| Set VMID divider for normal operation | VMID_SEL = 01                               | R2 (02h) [1:0]                |  |  |

Table 69 Recommended Power-Up Sequence

|                                                      |                                 | REGISTER[BITS]                 |
|------------------------------------------------------|---------------------------------|--------------------------------|
|                                                      | SPKR_PGA_ENA = 1                | R3 (03h) [13]                  |
|                                                      | SPKL_PGA_ENA = 1                | R3 (03h) [12]                  |
|                                                      | SPKR_VOL = 00h                  | R47 (2Fh) [5:0]                |
| Mute speaker PGA and DAC                             | SPKL_VOL = 00h                  | R48 (30h) [5:0]                |
| ·                                                    | DACR_MUTE = 1                   | R24 (18h) [8]                  |
|                                                      | DACL_MUTE = 1                   | R23 (17h) [8]                  |
|                                                      | DACR_VOL = 0                    | R24 (18h) [7:0]                |
|                                                      | DACL_VOL = 0                    | R23 (17h) [7:0]                |
| Select LDO for fast start-up                         | LDO_REF_SEL_FAST = 1            | R53 (35h) [14]                 |
| Ocicot EDO for last start-up                         | LDO_BIAS_SRC = 1                | R53 (35h) [5]                  |
|                                                      | VMID_SEL = 11                   | R2 (02h) [1:0]                 |
| Select VMID for fast start-up                        | VMID_FAST_START =1              | R7 (07h) [11]                  |
| Select VIVIID for last start-up                      | BIAS_SRC = 1                    | R7 (07h) [7]                   |
|                                                      | VMID_RAMP = 01                  | R7 (07h) [6:5]                 |
| Disabled VMID                                        | VMID ENA = 0                    | R7 (07h) [4]                   |
| Delay 500ms for VMID to discharge                    | VIVIIB_EIVY 0                   | 1(1 (011) [4]                  |
|                                                      |                                 | R42 (2Ah) [7]                  |
| Discharge outputs                                    | SPKR_DISCH = 1 SPKL_DISCH = 1   | R42 (2Ah) [6]                  |
| Delay 50ms for outputs to discharge                  | LINER_DISCH = 1 LINEL_DISCH = 1 | R42 (2Ah) [5]<br>R42 (2Ah) [4] |
|                                                      |                                 | R42 (2Ah) [9]                  |
|                                                      | LINER_MUTE = 1 LINEL_MUTE = 1   | R42 (2Ah) [8]                  |
| Mute outputs                                         | SPKR_OP_MUTE = 1                | R03 (03h) [9]                  |
|                                                      | SPKL_OP_MUTE = 1                | R03 (03h) [8]                  |
| Disable power to speaker driver (must be done before | SPKR_SPKVDD_ENA = 1             | R3 (03h) [11]                  |
| disabling the speaker outputs)                       | SPKL_SPKVDD_ENA = 1             | R3 (03h) [10]                  |
| Disable speaker outputs                              | SPKN_OP_ENA = 1 SPKP_OP_ENA     | R3 (03h) [7]                   |
| 2.000.0 oposor outparo                               | = 1                             | R3 (03h) [6]                   |
| Reset                                                | SW_RESET                        | R0 (00h) [15:0]                |
| Turn off external power supply voltages              |                                 |                                |

Table 70 Recommended Power-Down Sequence

WM8946

# **REGISTER MAP**

| REG       | NAME                        | 15                  | 14              | 13                   | 12                   | 11                          | 10                          | 9                    | 8                            | 7                   | 6                   | 5                     | 4                     | 3                    | 2                    | 1                   | 0                     | DEFAULT |
|-----------|-----------------------------|---------------------|-----------------|----------------------|----------------------|-----------------------------|-----------------------------|----------------------|------------------------------|---------------------|---------------------|-----------------------|-----------------------|----------------------|----------------------|---------------------|-----------------------|---------|
| R0 (0h)   | Software Reset/Chip<br>ID 1 |                     | •               |                      |                      |                             |                             |                      | SW_RES                       | SET[15:0            | ]                   | •                     |                       |                      |                      |                     |                       | 6229h   |
| R1 (1h)   | Chip ID 2                   | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     |                      | CHIP_F               | REV[3:0]            |                       | 0000h   |
| R2 (2h)   | Power management<br>1       | 0                   | 0               | INPPG<br>AR_E<br>NA  | INPPG<br>AL_EN<br>A  | ADCR<br>_ENA                | ADCL_<br>ENA                | 0                    | 0                            | DMIC_<br>ENA        | 0                   | 0                     | MICB_<br>ENA          | BIAS_<br>ENA         | VMID_<br>BUF_E<br>NA | VMID_S              | SEL[1:0]              | 0000h   |
| R3 (3h)   | Power management<br>2       | OUTR<br>_ENA        | OUTL_<br>ENA    | SPKR_<br>PGA_<br>ENA | SPKL_<br>PGA_<br>ENA | SPKR_<br>SPKV<br>DD_E<br>NA | SPKL_<br>SPKV<br>DD_E<br>NA | SPKR_<br>OP_M<br>UTE | SPKL_<br>OP_M<br>UTE         | SPKR_<br>OP_E<br>NA | SPKL_<br>OP_E<br>NA | SPKR_<br>MIX_M<br>UTE | SPKL_<br>MIX_M<br>UTE | SPKR_<br>MIX_E<br>NA | SPKL_<br>MIX_E<br>NA | DACR<br>_ENA        | DACL_<br>ENA          | 0330h   |
| R4 (4h)   | Audio Interface             |                     | ATA_PU<br>[1:0] | FRAME<br>1:          |                      | BCLK_                       | PULL[1:<br>)]               | ADCR<br>_SRC         | ADCL_<br>SRC                 | DACR<br>_SRC        | DACL_<br>SRC        | BCLK_<br>INV          | LRCLK<br>_INV         | WL                   | [1:0]                | FMT                 | [1:0]                 | 028Ah   |
| R5 (5h)   | Companding control          | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | LOOP<br>BACK          | 0                     | DAC_<br>COMP         | DAC_<br>COMP<br>MODE | ADC_<br>COMP        | ADC_<br>COMP<br>MODE  | 0000h   |
| R6 (6h)   | Clock Gen control           | OSC_<br>CLK_E<br>NA | _               | PULL[1:<br>)]        | CLKO<br>UT_SE<br>L   |                             | T_DIV[1<br>0]               | SYSCL<br>K_ENA       |                              | SYS                 | CLK_DI\             | V[2:0]                | TOCL<br>K_ENA         | BC                   | LK_DIV[:             | 2:0]                | MSTR                  | 0106h   |
| R7 (7h)   | Additional control          | 0                   | 0               | 0                    | 0                    | VMID_<br>FAST_<br>START     | VMID_<br>REF_S<br>EL        | VMID_<br>CTRL        | START<br>UP_BI<br>AS_EN<br>A | BIAS_<br>SRC        |                     | RAMP[1:               | VMID_<br>ENA          |                      | SR[                  | [3:0]               |                       | 000Dh   |
| R8 (8h)   | FLL Control 1               | 0                   | 0               | 0                    | FLL_CL               | K_REF<br>/[1:0]             | FLL <sub></sub>             | OUTDI                | /[2:0]                       | FLL_C               | TRL_RA              | TE[2:0]               | FLL <sub>.</sub>      | FRATIO               | [2:0]                | FLL_F<br>RAC        | FLL_E<br>NA           | 0102h   |
| R9 (9h)   | FLL Control 2               |                     | ,               |                      |                      |                             |                             |                      | FLL_k                        | ([15:0]             |                     |                       |                       |                      |                      |                     | 3127h                 |         |
| R10 (Ah)  | FLL Control 3               | 0                   |                 | 1                    |                      | 1                           | FLL_                        | N[9:0]               | 1                            | 1                   | 1                   |                       | 0                     |                      | FLL_G/               | AIN[3:0]            | 1                     | 0104h   |
| R11 (Bh)  | GPIO Config                 | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | 0                    | 0                   | MODE<br>_GPIO         | 0000h   |
| R12 (Ch)  | GPIO1 Control               | GP1_D<br>IR         | GP1_P           | ULL[1:0]             | GP1_I<br>NT_M<br>ODE | 0                           | GP1_P<br>OL                 | 0                    | 0                            | 0                   | 0                   | GP1_L<br>VL           | 0                     |                      | GP1_F                | N[3:0]              |                       | 8000h   |
| R13 (Dh)  | GPIO2 Control               | GP2_D<br>IR         | GP2_P           | ULL[1:0]             | GP2_I<br>NT_M<br>ODE | 0                           | GP2_P<br>OL                 | 0                    | 0                            | 0                   | 0                   | GP2_L<br>VL           | 0                     |                      | GP2_F                | FN[3:0]             |                       | 8000h   |
| R14 (Eh)  | GPIO3 Control               | GP3_D<br>IR         | GP3_P           | ULL[1:0]             | GP3_I<br>NT_M<br>ODE | 0                           | GP3_P<br>OL                 | 0                    | 0                            | 0                   | 0                   | GP3_L<br>VL           | 0                     |                      | GP3_F                | N[3:0]              |                       | C000h   |
| R15 (Fh)  | GPIO4 Control               | GP4_D<br>IR         | GP4_P           | ULL[1:0]             | GP4_I<br>NT_M<br>ODE | 0                           | GP4_P<br>OL                 | 0                    | 0                            | 0                   | 0                   | GP4_L<br>VL           | 0                     |                      | GP4_F                | N[3:0]              |                       | 8000h   |
| R16 (10h) | System Interrupts           | TEMP<br>_INT        | GP4_I<br>NT     | GP3_I<br>NT          | GP2_I<br>NT          | GP1_I<br>NT                 | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | 0                    | 0                   | LDO_<br>UV_IN<br>T    | 0000h   |
| R17 (11h) | Status Flags                | TEMP<br>_STS        | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | 0                    | 0                   | LDO_<br>UV_ST<br>S    | 0000h   |
| R18 (12h) | IRQ Config                  | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | 0                    | 0                   | IM_IR<br>Q            | 0001h   |
| R19 (13h) | System Interrupts<br>Mask   | _                   | IM_GP<br>4_INT  | _                    | IM_GP<br>2_INT       | IM_GP<br>1_INT              | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | 0                    | 0                   | IM_LD<br>O_UV_<br>INT | 0000h   |
| R20 (14h) | Control Interface           | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | 0                     | 0                    | SPI_O<br>D           | SPI_4<br>WIRE       | AUTO<br>_INC          | 0002h   |
| R21 (15h) | DAC Control 1               | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | DAC_<br>MUTE<br>ALL          | 0                   | 0                   | 0                     | DAC_<br>AUTO<br>MUTE  | 0                    | 0                    | DACR<br>_DATI<br>NV | DACL_<br>DATIN<br>V   | 0110h   |
| R22 (16h) | DAC Control 2               | 0                   | 0               | 0                    | 0                    | 0                           | 0                           | 0                    | 0                            | 0                   | 0                   | 0                     | DAC_<br>VOL_R         | 0                    | 0                    | 0                   | DAC_<br>SB_FL         | 0010h   |



| REG       | NAME                    | 15            | 14 | 13                           | 12                           | 11                            | 10                            | 9                  | 8                              | 7                    | 6                    | 5                     | 4                       | 3                              | 2                      | 1                      | 0                      | DEFAULT |
|-----------|-------------------------|---------------|----|------------------------------|------------------------------|-------------------------------|-------------------------------|--------------------|--------------------------------|----------------------|----------------------|-----------------------|-------------------------|--------------------------------|------------------------|------------------------|------------------------|---------|
|           |                         |               |    |                              |                              |                               |                               |                    |                                |                      |                      |                       | AMP                     |                                |                        |                        | Т                      |         |
| R23 (17h) | Left DAC digital Vol    | 0             | 0  | 0                            | DAC_<br>VU                   | 0                             | 0                             | 0                  | DACL_<br>MUTE                  |                      |                      |                       | DACL_\                  | /OL[7:0]                       |                        |                        |                        | 00C0h   |
| R24 (18h) | Right DAC digital Vol   | 0             | 0  | 0                            | DAC_<br>VU                   | 0                             | 0                             | 0                  | DACR<br>_MUT<br>E              |                      |                      |                       | DACR_\                  | VOL[7:0]                       |                        |                        |                        | 00C0h   |
| R25 (19h) | ADC Control 1           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | ADC_<br>MUTE<br>ALL            | 0                    | 0                    | 0                     | 0                       | 0                              | 0                      |                        | ADCL_<br>DATIN<br>V    | 0100h   |
| R26 (1Ah) | ADC Control 2           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | 0                              | 0                    | 0                    | 0                     | 0                       | 0                              |                        | IPF_CU<br>1:0]         | ADC_<br>HPF            | 0000h   |
| R27 (1Bh) | Left ADC Digital Vol    | 0             | 0  | 0                            | ADC_<br>VU                   | 0                             | 0                             | 0                  | ADCL_<br>MUTE                  |                      |                      |                       | ADCL_\                  | /OL[7:0]                       |                        |                        |                        | 00C0h   |
| R28 (1Ch) | Right ADC Digital Vol   | 0             | 0  | 0                            | ADC_<br>VU                   | 0                             | 0                             | 0                  | ADCR<br>_MUT<br>E              |                      |                      |                       | ADCR_\                  | VOL[7:0]                       |                        |                        |                        | 00C0h   |
| R29 (1Dh) | DRC Control 1           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | DRC_<br>NG_E<br>NA             | DRC_<br>ENA          | 0                    | 0                     | 0                       | 1                              | DRC_<br>QR             | DRC_<br>ANTIC<br>LIP   | 1                      | 000Fh   |
| R30 (1Eh) | DRC Control 2           | 0             | 0  | 0                            | DRO                          | C_NG_M                        | IINGAIN[                      | [3:0]              | 0                              | 0                    | 0                    | 1                     | DRC_                    | MINGAI                         | N[2:0]                 | _                      | MAXGAI<br>1:0]         | 0C25h   |
| R31 (1Fh) | DRC Control 3           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 1                  | 1                              |                      | DRC_A                | TK[3:0]               |                         |                                | DRC_D                  | CY[3:0]                |                        | 0342h   |
| R32 (20h) | DRC Control 4           | 0             | 0  | 0                            |                              | DRC_                          | KNEE2_                        | IP[4:0]            |                                |                      | D                    | RC_KNI                | EE_IP[5:                | 0]                             | 1                      | 0                      | 0                      | 0000h   |
| R33 (21h) | DRC Control 5           | 0             | 0  | DRC_<br>KNEE2<br>_OP_E<br>NA |                              | DRC_F                         | (NEE2_(                       | OP[4:0]            |                                |                      | DRC_                 | KNEE_C                | )P[4:0]                 |                                | DRC_                   | HI_COM                 | IP[2:0]                | 0003h   |
| R34 (22h) | DRC Control 6           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | 0                              | 0                    | 0                    | 0                     | 0                       |                                | R_THR[<br>0]           | DRC_C                  | R_DCY<br>:0]           | 0000h   |
| R35 (23h) | DRC Control 7           | 0             | 0  | 0                            | 0                            | 0                             | 0                             | DRC_N<br>1:        | G_EXP[<br>:0]                  | DRC_                 | LO_CON               | MP[2:0]               |                         | DR                             | C_INIT[4               | 4:0]                   |                        | 0000h   |
| R36 (24h) | DRC Status              |               |    | 1                            |                              |                               |                               |                    | DRC_G/                         | AIN[15:0]            |                      |                       |                         |                                | 1                      |                        |                        | 0000h   |
| R37 (25h) | Beep Control 1          | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | 0                              | 0                    |                      | BEEP_C                | SAIN[3:0]               |                                |                        | RATE[1:<br>)]          | BEEP_<br>ENA           | 0002h   |
| R38 (26h) | Video Buffer            | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | 0                              | VB_EN<br>A           | VB_Q<br>BOOS<br>T    | VB_G<br>AIN           | VB_                     | DISOFF                         | [2:0]                  | VB_PD                  | VB_CL<br>AMP           | 001Ch   |
| R39 (27h) | Input ctrl              | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | AUX2_<br>AUDIO                 | AUX1_<br>AUDIO       |                      |                       | MICLN<br>_TO_N<br>_PGAL |                                | R_SEL[<br>0]           |                        | L_SEL[<br>:0]          | 0035h   |
| R40 (28h) | Left INP PGA gain ctrl  | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | PGA_<br>VU                     | PGAL_<br>ZC          | PGAL_<br>MUTE        |                       |                         | PGAL_\                         | /OL[5:0]               |                        |                        | 0050h   |
| R41 (29h) | Right INP PGA gain ctrl | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | PGA_<br>VU                     | PGAR<br>_ZC          | PGAR<br>_MUT<br>E    |                       |                         | PGAR_\                         | VOL[5:0]               |                        |                        | 0050h   |
| R42 (2Ah) | Output ctrl             | THER<br>R_ACT | 0  | SPKR_<br>VMID_<br>OP_E<br>NA | SPKL_<br>VMID_<br>OP_E<br>NA | LINER<br>_VMID<br>_OP_E<br>NA | LINEL<br>_VMID<br>_OP_E<br>NA | LINER<br>_MUT<br>E | LINEL<br>_MUT<br>E             | SPKR_<br>DISCH       | SPKL_<br>DISCH       | LINER<br>_DISC<br>H   | LINEL<br>_DISC<br>H     | 0                              | 0                      | SPK_V<br>ROI           | LINE_<br>VROI          | 8300h   |
| R43 (2Bh) | SPK mixer control1      | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | AUX1_<br>TO_SP<br>KL           | PGAL_<br>TO_SP<br>KL | BYPL_<br>TO_P<br>GAL |                       | MDAC<br>R_TO_<br>PGAL   | DACL_<br>TO_P<br>GAL           | DACR<br>_TO_P<br>GAL   | _                      | AUX1_<br>TO_P<br>GAL   | 0000h   |
| R44 (2Ch) | SPK mixer control2      | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | AUX1_<br>TO_SP<br>KR           | PGAR<br>_TO_S<br>PKR | BYPR_<br>TO_P<br>GAR | MDAC<br>L_TO_<br>PGAR | MDAC<br>R_TO_<br>PGAR   | DACL_<br>TO_P<br>GAR           | DACR<br>_TO_P<br>GAR   | AUX2_<br>TO_P<br>GAR   | AUX1_<br>TO_P<br>GAR   | 0000h   |
| R45 (2Dh) | SPK mixer control3      | 0             | 0  | 0                            | 0                            | 0                             | 0                             | 0                  | AUX1_<br>TO_SP<br>KL_AT<br>TEN | PGAL_<br>TO_SP       | BYPL_                | 0                     | 0                       | DACL_<br>TO_P<br>GAL_A<br>TTEN | DACR<br>_TO_P<br>GAL_A | AUX2_<br>TO_P<br>GAL_A | AUX1_<br>TO_P<br>GAL_A | 0000h   |



| REG         | NAME                   | 45    | 14                  | 12            | 42         | 11                 | 10     | 9            | 8              | 7             | 6             | 5              | 4             | 3             | 2             | 1             | 0             | DEFAULT |
|-------------|------------------------|-------|---------------------|---------------|------------|--------------------|--------|--------------|----------------|---------------|---------------|----------------|---------------|---------------|---------------|---------------|---------------|---------|
|             | NAME                   | 15    | 14                  | 13            | 12         | 11                 | 10     |              |                |               |               |                |               |               | 2             |               | -             |         |
| R46 (2Eh)   | SPK mixer control4     | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | AUX1_<br>TO_SP | PGAR<br>_TO_S | _             | 0              | 0             | DACL_<br>TO_P | DACR<br>_TO_P | AUX2_<br>TO_P | AUX1_<br>TO_P | 0000h   |
|             |                        |       |                     |               |            |                    |        |              | KR_AT          | PKR_A         | GAR_          |                |               | GAR_          | GAR_          | GAR_          | GAR_          |         |
|             |                        |       |                     |               |            |                    |        |              | TEN            | TTEN          | ATTEN         |                |               | _             | _             | ATTEN         | _             |         |
| R47 (2Fh)   | Left SPK volume ctrl   | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | SPK_V          | SPKL          | SPKL_         |                | l             |               | VOL[5:0]      | 1             |               | 0079h   |
| ,           |                        |       |                     |               |            |                    |        |              | U              | ZC            | PGA_          |                |               | _             |               |               |               |         |
|             |                        |       |                     |               |            |                    |        |              |                |               | MUTE          |                |               |               |               |               |               |         |
| R48 (30h)   | Right SPK volume       | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | SPK_V          | SPKR_         | SPKR_         |                |               | SPKR_         | VOL[5:0]      |               |               | 0079h   |
|             | ctrl                   |       |                     |               |            |                    |        |              | U              | ZC            | PGA_          |                |               |               |               |               |               |         |
|             |                        |       |                     |               |            |                    |        |              |                |               | MUTE          |                | 1             |               |               |               |               |         |
| R49 (31h)   | Line L mixer control 1 | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | BYPL_         | MDAC           | MDAC          | DACL_         | DACR          | _             | AUX1_         | 0000h   |
|             |                        |       |                     |               |            |                    |        |              |                |               | TO_O<br>UTL   | L_TO_<br>OUTL  | R_TO_<br>OUTL | TO_O<br>UTL   | _10_0<br>UTL  | TO_O<br>UTL   | TO_O<br>UTL   |         |
| DE0 (20h)   | Line P miver central   | 0     | 0                   | _             | 0          | 0                  | 0      | 0            | 0              | 0             | BYPR          | MDAC           | MDAC          | DACL_         | DACR          | AUX2          | AUX1_         | 00006   |
| R50 (32h)   | Line R mixer control   | U     | U                   | 0             | U          | U                  | U      | U            | U              | U             | TO_0          | L_TO_          | R_TO_         | TO_O          | _TO_O         | _             | TO_0          | 0000h   |
|             |                        |       |                     |               |            |                    |        |              |                |               | UTR           | OUTR           | OUTR          | UTR           | UTR           | UTR           | UTR           |         |
| R51 (33h)   | Line L mixer control 2 | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | BYPL_         | 0              | 0             | DACL_         |               | AUX2_         | AUX1_         | 0000h   |
| (4.7)       |                        |       |                     |               |            |                    |        |              |                |               | TO_O          |                |               | TO_0          | _TO_O         | _             | TO_0          |         |
|             |                        |       |                     |               |            |                    |        |              |                |               | UTL_A         |                |               | UTL_A         | UTL_A         | UTL_A         | UTL_A         |         |
|             |                        |       |                     |               |            |                    |        |              |                |               | TTEN          |                |               | TTEN          | TTEN          | TTEN          | TTEN          |         |
| R52 (34h)   | Line R mixer control   | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | BYPR_         | 0              | 0             | DACL_         | DACR          | _             | AUX1_         | 0000h   |
|             | 2                      |       |                     |               |            |                    |        |              |                |               | TO_0          |                |               | TO_0          |               | TO_0          | TO_0          |         |
|             |                        |       |                     |               |            |                    |        |              |                |               | UTR_A<br>TTEN |                |               | TTEN          | _             | UTR_A<br>TTEN | TTEN          |         |
| DE2 (25h)   | LDO                    | LDO E | LDO                 | LDO           | LDO        | 0                  | 0      | 0            | 0              | 0             | 0             | IDO B          |               | 1             | 1             |               | IILIN         | 0007h   |
| R53 (35h)   | LDO                    | NA    | _                   | LDO_<br>REF_S | _          | U                  | U      | U            | U              | U             | U             | LDO_B<br>IAS_S |               | LD            | O_VSEL        | [4:0]         |               | 0007h   |
|             |                        | INA   | EL_FA               | EL            | OITLI      |                    |        |              |                |               |               | RC             |               |               |               |               |               |         |
|             |                        |       | ST                  |               |            |                    |        |              |                |               |               |                |               |               |               |               |               |         |
| R54 (36h)   | Bandgap                | BG_E  | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | 0             | 0              |               | BG            | S_VSEL[4      | 4:0]          |               | 000Ah   |
|             |                        | NA    |                     |               |            |                    |        |              |                |               |               |                |               |               |               |               |               |         |
| R64 (40h)   | SE Config Selection    | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | 0             | 0              | 0             |               | SE_CON        | NFIG[3:0]     | ]             | 0000h   |
| R65 (41h)   | SE1_LHPF_CONFIG        | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | 0             | SE1_L          | SE1_L         | 0             | 0             | SE1_L         | _             | 0000h   |
|             |                        |       |                     |               |            |                    |        |              |                |               |               | HPF_R          |               |               |               | HPF_R         |               |         |
|             | 054 11185 1            |       |                     |               |            |                    |        | J            |                |               | <u> </u>      | _SIGN          | _SIGN         |               |               | _ENA          | _ENA          |         |
| R66 (42h)   | SE1_LHPF_L             |       |                     |               |            |                    |        |              | SE1_LHF        |               |               |                |               |               |               |               |               | 0000h   |
| R67 (43h)   | SE1_LHPF_R             |       |                     | ı             |            |                    |        |              | E1_LHP         |               | r e           | ı              | ı             | 1             | 1             | ı             | 1             | 0000h   |
| R68 (44h)   | SE1_3D_CONFIG          | 0     | 0                   | 0             | SE1_3      | 0                  | 0      | _            | SE1_3          | _             | _             | _              | _             | 0             | 0             | _             | SE1_3         | 0000h   |
|             |                        |       |                     |               | D_MO<br>NO |                    |        | D_R_S<br>IGN | D_L_S<br>IGN   |               |               | D_R_L<br>HPF_S | D_L_L         |               |               | D_R_E<br>NA   | D_L_E<br>NA   |         |
|             |                        |       |                     |               | NO         |                    |        | IOIV         | ION            | NA NA         |               | IGN            |               |               |               | INA           | INA           |         |
| R69 (45h)   | SE1_3D_L               | 0     | 0                   | SF1 3F        | ) L DEL    | AY[2:0]            | SF1 3F | ) I CU       | TOFFI2:        |               |               | CGAIN          |               | SE            | 1 3D I        | _FGAIN[;      | 3.01          | 0408h   |
| 1100 (1011) | 0203_2                 | Ů     |                     | 021_02        |            | , (1 <u>[</u> 2.0] | 021_02 | 0]           |                | 02            | 1_00          | _00/11/1       | 0.0]          | 0.2           | 00            | _1            | 0.0]          | 0 10011 |
| R70 (46h)   | SE1_3D_R               | 0     | 0                   | SE1 3E        | R_DEL      | .AY[2:0]           | SE1 3E | R CU         | TOFF[2:        | SE            | 1 3D R        | _CGAIN[        | 3:01          | SE            | 1 3D R        | FGAIN         | 3:01          | 0408h   |
| ,           |                        |       |                     | _             |            |                    | _      | 0]           | •              |               |               |                | •             |               |               |               | •             |         |
| R71 (47h)   | SE1_NOTCH_CONFI        | 0     | 0                   | 0             | 0          | 0                  | 0      | 0            | 0              | 0             | 0             | 0              | 0             | 0             | 0             | SE1_N         | SE1_N         | 0000h   |
|             | G                      |       |                     |               |            |                    |        |              |                |               |               |                |               |               |               |               | OTCH          |         |
|             |                        |       |                     |               |            |                    |        |              |                |               |               |                |               |               |               |               | _L_EN         |         |
|             | 054 NG5511 115         |       |                     |               |            |                    |        |              |                | <u> </u>      |               |                |               | L             | L             | Α             | Α             |         |
| R72 (48h)   | SE1_NOTCH_A10          |       |                     |               |            |                    |        |              | 1_NOTC         |               |               |                |               |               |               |               |               | 0000h   |
| R73 (49h)   | SE1_NOTCH_A11          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A11[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R74 (4Ah)   | SE1_NOTCH_A20          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A20[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R75 (4Bh)   | SE1_NOTCH_A21          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A21[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R76 (4Ch)   | SE1_NOTCH_A30          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A30[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R77 (4Dh)   | SE1_NOTCH_A31          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A31[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R78 (4Eh)   | SE1_NOTCH_A40          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A40[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R79 (4Fh)   | SE1_NOTCH_A41          |       |                     |               |            |                    |        | SE           | 1_NOTC         | H_A41[1       | 5:0]          |                |               |               |               |               |               | 0000h   |
| R80 (50h)   | SE1_NOTCH_A50          |       |                     |               |            |                    |        |              | 1_NOTC         |               |               |                |               |               |               |               |               | 0000h   |
| R81 (51h)   | SE1_NOTCH_A51          |       |                     |               |            |                    |        |              |                |               |               |                |               |               |               |               |               | 0000h   |
| R82 (52h)   | SE1_NOTCH_M10          |       |                     |               |            |                    |        |              |                |               |               | 0000h          |               |               |               |               |               |         |
| 1102 (0211) |                        |       | SE1_NOTCH_M10[15:0] |               |            |                    |        |              |                |               |               |                | UUUUII        |               |               |               |               |         |



|                    |                       |    |                      |                  |    |    |    |     |             | _        |       |       |   | т.    | _ | 1 . |                       |         |
|--------------------|-----------------------|----|----------------------|------------------|----|----|----|-----|-------------|----------|-------|-------|---|-------|---|-----|-----------------------|---------|
| REG                | NAME                  | 15 | 14                   | 13               | 12 | 11 | 10 | 9   | 8           | 7        | 6     | 5     | 4 | 3     | 2 | 1   | 0                     | DEFAULT |
| <u> </u>           | SE1_NOTCH_M11         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 1000h   |
| <u> </u>           | SE1_NOTCH_M20         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 0000h   |
| ( /                | SE1_NOTCH_M21         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 1000h   |
|                    | SE1_NOTCH_M30         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 0000h   |
| , ,                | SE1_NOTCH_M31         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 1000h   |
|                    | SE1_NOTCH_M40         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 0000h   |
| <del>  ` '  </del> | SE1_NOTCH_M41         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 1000h   |
| · '                | SE1_NOTCH_M50         |    |                      |                  |    |    |    |     | I_NOTCI     |          |       |       |   |       |   |     |                       | 0000h   |
| ` '                | SE1_NOTCH_M51         |    |                      |                  |    |    | _  |     | I_NOTCI     |          |       |       |   | Т.    | _ | 1   | I                     | 1000h   |
| R92 (5Ch)          | SE1_DF1_CONFIG        | 0  | 0                    | 0                | 0  | 0  | 0  | 0   | 0           | 0        | 0     | 0     | 0 | 0     | 0 |     | SE1_D<br>F1_L_<br>ENA | 0000h   |
| R93 (5Dh)          | SE1_DF1_L0            |    |                      |                  |    |    |    | 5   | SE1_DF1     | _L0[15:0 | )]    |       |   |       |   |     |                       | 1000h   |
| R94 (5Eh)          | SE1_DF1_L1            |    |                      |                  |    |    |    | 9   | SE1_DF1     | _L1[15:0 | )]    |       |   |       |   |     |                       | 0000h   |
| R95 (5Fh)          | SE1_DF1_L2            |    |                      |                  |    |    |    | 9   | SE1_DF1     | _L2[15:0 | )]    |       |   |       |   |     |                       | 0000h   |
| R96 (60h)          | SE1_DF1_R0            |    |                      |                  |    |    |    | 5   | E1_DF1      | _R0[15:0 | 0]    |       |   |       |   |     |                       | 1000h   |
| R97 (61h)          | SE1_DF1_R1            |    |                      |                  |    |    |    | 5   | E1_DF1      | _R1[15:0 | 0]    |       |   |       |   |     |                       | 0000h   |
| R98 (62h)          | SE1_DF1_R2            |    |                      |                  |    |    |    | 5   | E1_DF1      | _R2[15:0 | 0]    |       |   |       |   |     |                       | 0000h   |
| , ,                | SE2_RETUNE_CON<br>FIG | 0  | 0                    | SE1_DF1_R2[15:0] |    |    |    |     |             |          |       |       |   | 0000h |   |     |                       |         |
| R101 (65h)         | SE2_RETUNE_C0         |    |                      | •                |    |    |    | SE  | <br>2_RETUI | NE_C0[1  | 5:0]  |       |   |       |   |     | 1                     | 1000h   |
| R102 (66h)         | SE2_RETUNE_C1         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C1[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R103 (67h)         | SE2_RETUNE_C2         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C2[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R104 (68h)         | SE2_RETUNE_C3         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C3[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R105 (69h)         | SE2_RETUNE_C4         |    |                      |                  |    |    |    |     | <br>2_RETUI |          |       |       |   |       |   |     |                       | 0000h   |
| R106 (6Ah)         | SE2_RETUNE_C5         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C5[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R107 (6Bh)         | SE2_RETUNE_C6         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C6[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R108 (6Ch)         | SE2_RETUNE_C7         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C7[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R109 (6Dh)         | SE2_RETUNE_C8         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C8[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R110 (6Eh)         | SE2_RETUNE_C9         |    |                      |                  |    |    |    | SE  | 2_RETUI     | NE_C9[1  | 5:0]  |       |   |       |   |     |                       | 0000h   |
| R111 (6Fh)         | SE2_RETUNE_C10        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C10[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R112 (70h)         | SE2_RETUNE_C11        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C11[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R113 (71h)         | SE2_RETUNE_C12        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C12[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R114 (72h)         | SE2_RETUNE_C13        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C13[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R115 (73h)         | SE2_RETUNE_C14        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C14[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R116 (74h)         | SE2_RETUNE_C15        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C15[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R117 (75h)         | SE2_RETUNE_C16        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C16[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R118 (76h)         | SE2_RETUNE_C17        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C17[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R119 (77h)         | SE2_RETUNE_C18        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C18[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R120 (78h)         | SE2_RETUNE_C19        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C19[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R121 (79h)         | SE2_RETUNE_C20        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C20[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R122 (7Ah)         | SE2_RETUNE_C21        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C21[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R123 (7Bh)         | SE2_RETUNE_C22        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C22[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R124 (7Ch)         | SE2_RETUNE_C23        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C23[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R125 (7Dh)         | SE2_RETUNE_C24        |    | SE2_RETUNE_C24[15:0] |                  |    |    |    |     |             |          |       | 0000h |   |       |   |     |                       |         |
| R126 (7Eh)         | SE2_RETUNE_C25        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C25[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R127 (7Fh)         | SE2_RETUNE_C26        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C26[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R128 (80h)         | SE2_RETUNE_C27        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C27[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R129 (81h)         | SE2_RETUNE_C28        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C28[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R130 (82h)         | SE2_RETUNE_C29        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C29[  | 15:0] |       |   |       |   |     |                       | 0000h   |
| R131 (83h)         | SE2_RETUNE_C30        |    |                      |                  |    |    |    | SE2 | _RETUN      | IE_C30[  | 15:0] |       |   |       |   |     |                       | 0000h   |
|                    | SE2_RETUNE_C31        |    |                      |                  |    |    |    | SE2 | _RETUN      | IF C31[  | 15:01 |       |   |       |   |     |                       | 0000h   |



| REG              | NAME                         | 15 | 14                                       | 13 | 12 | 11     | 10     | 9       | 8          | 7           | 6    | 5 | 4 | 3     | 2       | 1       | 0     | DEFAULT        |
|------------------|------------------------------|----|------------------------------------------|----|----|--------|--------|---------|------------|-------------|------|---|---|-------|---------|---------|-------|----------------|
| R133 (85h)       | SE2_5BEQ_CONFIG              | 0  | 0                                        | 0  | 0  | 0      | 0      | 0       | 0          | 0           | 0    | 0 | 0 | 0     | 0       | 0       | SE2_5 | 0000h          |
|                  |                              |    |                                          |    |    |        |        |         |            |             |      |   |   |       |         |         | BEQ_L |                |
| D404 (00L)       | 050 5050 1400                | •  |                                          |    |    | 050.5  |        | 074.03  |            | •           | •    |   |   | 050   |         | 2014.03 | _ENA  | 2020           |
|                  | SE2_5BEQ_L10G                | 0  | 0                                        | 0  |    |        | BEQ_L  |         |            | 0           | 0    | 0 |   |       | SBEQ_LO |         |       | 0C0Ch          |
|                  | SE2_5BEQ_L32G                | 0  | 0                                        | 0  | 0  | 0<br>0 | BEQ_L3 | 0       | 0          | 0           | 0    | 0 |   |       | SBEQ_L2 |         |       | 0C0Ch<br>000Ch |
| <u> </u>         | SE2_5BEQ_L4G<br>SE2_5BEQ_L0P | U  | U                                        | U  | U  | U      | U      |         | 2_5BEC     |             |      | U |   | SEZ_C | 5BEQ_L4 | 10[4:0] |       | 000Ch          |
| _ ` '            | SE2_5BEQ_L0A                 |    |                                          |    |    |        |        |         | 2_5BEG     |             |      |   |   |       |         |         |       | 0FCAh          |
| — ` <i>′</i>     | SE2_5BEQ_L0B                 |    |                                          |    |    |        |        |         | 2_5BEG     |             |      |   |   |       |         |         |       | 0400h          |
| . ,              | SE2_5BEQ_L1P                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 01C5h          |
|                  | SE2_5BEQ_L1A                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 1EB5h          |
| <del></del>      | SE2_5BEQ_L1B                 |    |                                          |    |    |        |        |         | <br>2_5BEC |             |      |   |   |       |         |         |       | F145h          |
|                  | SE2_5BEQ_L1C                 |    |                                          |    |    |        |        |         | <br>2_5BEC |             |      |   |   |       |         |         |       | 0B75h          |
| R144 (90h)       | SE2_5BEQ_L2P                 |    |                                          |    |    |        |        |         | <br>2_5BEC |             |      |   |   |       |         |         |       | 0558h          |
| R145 (91h)       | SE2_5BEQ_L2A                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | <br>_L2A[15 | 5:0] |   |   |       |         |         |       | 1C58h          |
| R146 (92h)       | SE2_5BEQ_L2B                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | )_L2B[15    | 5:0] |   |   |       |         |         |       | F373h          |
| R147 (93h)       | SE2_5BEQ_L2C                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _L2C[15     | 5:0] |   |   |       |         |         |       | 0A54h          |
| R148 (94h)       | SE2_5BEQ_L3P                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _L3P[15     | 5:0] |   |   |       |         |         |       | 1103h          |
| R149 (95h)       | SE2_5BEQ_L3A                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | )_L3A[15    | 5:0] |   |   |       |         |         |       | 168Eh          |
| R150 (96h)       | SE2_5BEQ_L3B                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | )_L3B[15    | 5:0] |   |   |       |         |         |       | F829h          |
| R151 (97h)       | SE2_5BEQ_L3C                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _L3C[15     | 5:0] |   |   |       |         |         |       | 07Adh          |
| R152 (98h)       | SE2_5BEQ_L4P                 |    |                                          |    |    |        |        | SE      | E2_5BEC    | _L4P[15     | 5:0] |   |   |       |         |         |       | 4000h          |
| R153 (99h)       | SE2_5BEQ_L4A                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | )_L4A[15    | 5:0] |   |   |       |         |         |       | 0564h          |
| R154 (9Ah)       | SE2_5BEQ_L4B                 |    | 1                                        | 1  |    |        |        | SE      | 2_5BEC     | _L4B[15     | 5:0] | 1 | 1 |       |         |         |       | 0559h          |
| R155 (9Bh)       | SE2_5BEQ_R10G                | 0  | 0                                        | 0  |    | SE2_5  | BEQ_R  | 1G[4:0] |            | 0           | 0    | 0 |   | SE2_5 | BEQ_R   | OG[4:0] |       | 0C0Ch          |
| R156 (9Ch)       | SE2_5BEQ_R32G                | 0  | 0                                        | 0  |    | SE2_5  | BEQ_R  | 3G[4:0] | 1          | 0           | 0    | 0 |   | SE2_5 | BEQ_R   | 2G[4:0] |       | 0C0Ch          |
| <del></del>      | SE2_5BEQ_R4G                 | 0  | 0                                        | 0  | 0  | 0      | 0      | 0       | 0          | 0           | 0    | 0 |   | SE2_5 | BEQ_R   | 4G[4:0] |       | 000Ch          |
| R158 (9Eh)       | SE2_5BEQ_R0P                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _R0P[1      | 5:0] |   |   |       |         |         |       | 00D8h          |
| <u> </u>         | SE2_5BEQ_R0A                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _R0A[1      | 5:0] |   |   |       |         |         |       | 0FCAh          |
|                  | SE2_5BEQ_R0B                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 0400h          |
|                  | SE2_5BEQ_R1P                 |    |                                          |    |    |        |        | SE      | 2_5BEC     | _R1P[1      | 5:0] |   |   |       |         |         |       | 01C5h          |
|                  | SE2_5BEQ_R1A                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 1EB5h          |
| _ ` ′            | SE2_5BEQ_R1B                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | F145h          |
| · , ,            | SE2_5BEQ_R1C                 |    |                                          |    |    |        |        |         | 2_5BEQ     |             |      |   |   |       |         |         |       | 0B75h          |
|                  | SE2_5BEQ_R2P                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 0558h          |
| <del></del>      | SE2_5BEQ_R2A                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 1C58h          |
|                  | SE2_5BEQ_R2B                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | F373h          |
|                  | SE2_5BEQ_R2C                 |    | SE2_5BEQ_R2C[15:0]                       |    |    |        |        |         |            | 0A54h       |      |   |   |       |         |         |       |                |
|                  | SE2_5BEQ_R3P                 |    | SE2_5BEQ_R3P[15:0]<br>SE2_5BEQ_R3A[15:0] |    |    |        |        |         |            | 1103h       |      |   |   |       |         |         |       |                |
| <del>- ` ´</del> | SE2_5BEQ_R3A<br>SE2_5BEQ_R3B |    |                                          |    |    |        |        |         |            |             |      |   |   |       |         |         |       | 168Eh          |
|                  | SE2_5BEQ_R3C                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | F829h          |
| <b>— ` </b>      | SE2_5BEQ_R3C<br>SE2_5BEQ_R4P |    |                                          |    |    |        |        |         | 2_5BEQ     |             |      |   |   |       |         |         |       | 07Adh          |
| <u> </u>         | SE2_5BEQ_R4A                 |    |                                          |    |    |        |        |         | 2_5BEC     |             |      |   |   |       |         |         |       | 4000h<br>0564h |
|                  | SE2_5BEQ_R4B                 |    | SE2_5BEQ_R4A[15:0] SE2_5BEQ_R4B[15:0]    |    |    |        |        |         |            | 0559h       |      |   |   |       |         |         |       |                |
| VII (WIII)       | OLZ_VDLW_INHD                |    |                                          |    |    |        |        | 30      | L_JDE      | CL/4D[ ]    | ر٥.٠ |   |   |       |         |         |       | บบบอก          |



WM8946

## **REGISTER BITS BY ADDRESS**

Production Data

The complete register map is shown below. The detailed description can be found in the relevant text of the device description.

| REGISTER                                   | BIT  | LABEL              | DEFAULT                      | DESCRIPTION                                                                                                                             | REFER TO |
|--------------------------------------------|------|--------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------|
| ADDRESS                                    |      |                    |                              |                                                                                                                                         |          |
| R0 (00h)<br>Software<br>Reset/Chip<br>ID 1 | 15:0 | SW_RESET<br>[15:0] | 0110_0010<br>_0010_100<br>_1 | Writing to this register resets all registers to their default state.  Reading from this register will indicate device family ID 6229h. |          |

Register 00h Software Reset/Chip ID 1

| REGISTER<br>ADDRESS   | BIT | LABEL         | DEFAULT | DESCRIPTION                                               | REFER TO |
|-----------------------|-----|---------------|---------|-----------------------------------------------------------|----------|
| R1 (01h)<br>Chip ID 2 | 3:0 | CHIP_REV[3:0] | 0000    | Reading from this register will indicate the Revision ID. |          |

Register 01h Chip ID 2

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                      | REFER TO |
|---------------------|-----|-------------|---------|--------------------------------------------------------------------------------------------------|----------|
| R2 (02h)            | 13  | INPPGAR_EN  | 0       | Right Input PGA Enable                                                                           |          |
| Power               |     | Α           |         | 0 = Disabled                                                                                     |          |
| management<br>1     |     |             |         | 1 = Enabled                                                                                      |          |
| '                   | 12  | INPPGAL_ENA | 0       | Left Input PGA Enable                                                                            |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |
|                     | 11  | ADCR_ENA    | 0       | Right ADC Enable                                                                                 |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |
|                     |     |             |         | ADCR_ENA must be set to 1 when processing right channel data from the ADC or Digital Microphone. |          |
|                     | 10  | ADCL_ENA    | 0       | Left ADC Enable                                                                                  |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |
|                     |     |             |         | ADCL_ENA must be set to 1 when processing left channel data from the ADC or Digital Microphone.  |          |
|                     | 7   | DMIC_ENA    | 0       | Enables Digital Microphone mode                                                                  |          |
|                     |     | _           |         | 0 = Audio DSP input is from ADC                                                                  |          |
|                     |     |             |         | 1 = Audio DSP input is from digital microphone interface                                         |          |
|                     |     |             |         | When DMIC_ENA = 0, the Digital microphone clock (DMICCLK) is held low.                           |          |
|                     | 4   | MICB_ENA    | 0       | Microphone Bias Enable                                                                           |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |
|                     | 3   | BIAS_ENA    | 0       | Master Bias Enable                                                                               |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |
|                     | 2   | VMID_BUF_EN | 0       | VMID Buffer Enable.                                                                              |          |
|                     |     | А           |         | (The buffered VMID may be applied to disabled input and output pins.)                            |          |
|                     |     |             |         | 0 = Disabled                                                                                     |          |
|                     |     |             |         | 1 = Enabled                                                                                      |          |



| REGISTER | BIT | LABEL         | DEFAULT | DESCRIPTION                                   | REFER TO |
|----------|-----|---------------|---------|-----------------------------------------------|----------|
| ADDRESS  |     |               |         |                                               |          |
|          | 1:0 | VMID_SEL[1:0] | 00      | VMID Divider Enable and Select                |          |
|          |     |               |         | 00 = VMID disabled (for OFF mode)             |          |
|          |     |               |         | 01 = 2 x 50k divider (for normal operation)   |          |
|          |     |               |         | 10 = 2 x 250k divider (for low power standby) |          |
|          |     |               |         | 11 = 2 x 5k divider (for fast start-up)       |          |

Register 02h Power management 1

| REGISTER        | BIT | LABEL           | DEFAULT | DESCRIPTION                                                                             | REFER TO |
|-----------------|-----|-----------------|---------|-----------------------------------------------------------------------------------------|----------|
| ADDRESS         |     |                 |         |                                                                                         |          |
| R3 (03h)        | 15  | OUTR_ENA        | 0       | LINEOUTR enable                                                                         |          |
| Power           |     |                 |         | 0 = Disabled                                                                            |          |
| management<br>2 |     |                 |         | 1 = Enabled                                                                             |          |
| 2               | 14  | OUTL_ENA        | 0       | LINEOUTL enable                                                                         |          |
|                 |     |                 |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 | 13  | SPKR_PGA_E      | 0       | Speaker Right PGA enable                                                                |          |
|                 |     | NA              |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 | 12  | SPKL_PGA_E      | 0       | Speaker Left PGA enable                                                                 |          |
|                 |     | NA              |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 | 11  | SPKR_SPKVD      | 0       | SPKOUTR enable                                                                          |          |
|                 |     | D_ENA           |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 |     |                 |         | Note that SPKOUTR is also controlled by                                                 |          |
|                 |     |                 |         | SPKR_OP_ENA. When powering down SPKOUTR, the SPKR SPKVDD ENA bit should be reset first. |          |
|                 | 10  | SPKL_SPKVD      | 0       | SPKOUTL enable                                                                          |          |
|                 | 10  | D_ENA           |         | 0 = Disabled                                                                            |          |
|                 |     | _               |         | 1 = Enabled                                                                             |          |
|                 |     |                 |         | Note that SPKOUTL is also controlled by                                                 |          |
|                 |     |                 |         | SPKL_OP_ENA. When powering down SPKOUTL, the                                            |          |
|                 |     |                 |         | SPKL_SPKVDD_ENA bit should be reset first                                               |          |
|                 | 9   | SPKR_OP_MU      | 1       | SPKOUTR Output Mute                                                                     |          |
|                 |     | TE              |         | 0 = Disable Mute                                                                        |          |
|                 |     |                 |         | 1 = Enable Mute                                                                         |          |
|                 | 8   | SPKL_OP_MU      | 1       | SPKOUTL Output Mute                                                                     |          |
|                 |     | TE              |         | 0 = Disable Mute                                                                        |          |
|                 |     |                 |         | 1 = Enable Mute                                                                         |          |
|                 | 7   | SPKR_OP_EN<br>A | 0       | SPKOUTR enable                                                                          |          |
|                 |     | A               |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 |     |                 |         | Note that SPKOUTR is also controlled by SPKR_SPKVDD_ENA. When powering up SPKOUTR,      |          |
|                 |     |                 |         | the SPKR_OP_ENA bit should be enabled first.                                            |          |
|                 | 6   | SPKL_OP_EN      | 0       | SPKOUTL enable                                                                          |          |
|                 |     | A               |         | 0 = Disabled                                                                            |          |
|                 |     |                 |         | 1 = Enabled                                                                             |          |
|                 |     |                 |         | Note that SPKOUTL is also controlled by                                                 |          |
|                 |     |                 |         | SPKL_SPKVDD_ENA. When powering up SPKOUTL,                                              |          |
|                 |     |                 |         | the SPKL_OP_ENA bit should be enabled first                                             |          |
|                 | 5   | SPKR_MIX_M      | 1       | Right Speaker PGA Mixer Mute                                                            |          |
|                 |     | UTE             |         | 0 = Disable Mute                                                                        |          |



| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                          | REFER TO |
|---------------------|-----|-------------|---------|------------------------------------------------------------------------------------------------------|----------|
|                     |     |             |         | 1 = Enable Mute                                                                                      |          |
|                     | 4   | SPKL_MIX_MU | 1       | Left Speaker PGA Mixer Mute                                                                          |          |
|                     |     | TE          |         | 0 = Disable Mute                                                                                     |          |
|                     |     |             |         | 1 = Enable Mute                                                                                      |          |
|                     | 3   | SPKR_MIX_EN | 0       | Right speaker output mixer enable                                                                    |          |
|                     |     | Α           |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 2   | SPKL_MIX_EN | 0       | Left speaker output mixer enable                                                                     |          |
|                     |     | A           |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 1   | DACR_ENA    | 0       | Right DAC Enable                                                                                     |          |
|                     |     |             |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     |     |             |         | DACR_ENA must be set to 1 when processing right channel data from the DAC or Digital Beep Generator. |          |
|                     | 0   | DACL_ENA    | 0       | Left DAC Enable                                                                                      |          |
|                     |     |             |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     |     |             |         | DACR_ENA must be set to 1 when processing left channel data from the DAC or Digital Beep Generator.  |          |

Register 03h Power management 2

| REGISTER<br>ADDRESS | BIT   | LABEL      | DEFAULT | DESCRIPTION                                   | REFER TO |
|---------------------|-------|------------|---------|-----------------------------------------------|----------|
| R4 (04h)            | 15:14 | DACDATA_PU | 00      | DACDAT pull-up / pull-down Enable             |          |
| Audio               |       | LL[1:0]    |         | 00 = no pull-up or pull-down                  |          |
| Interface           |       |            |         | 01 = pull-down                                |          |
|                     |       |            |         | 10 = pull-up                                  |          |
|                     |       |            |         | 11 = reserved                                 |          |
|                     | 13:12 | FRAME_PULL | 00      | LRCLK pull-up / pull-down Enable              |          |
|                     |       | [1:0]      |         | 00 = no pull-up or pull-down                  |          |
|                     |       |            |         | 01 = pull-down                                |          |
|                     |       |            |         | 10 = pull-up                                  |          |
|                     |       |            |         | 11 = reserved                                 |          |
|                     | 11:10 | BCLK_PULL  | 00      | BCLK pull-up / pull-down Enable               |          |
|                     |       | [1:0]      |         | 00 = no pull-up or pull-down                  |          |
|                     |       |            |         | 01 = pull-down                                |          |
|                     |       |            |         | 10 = pull-up                                  |          |
|                     |       |            |         | 11 = reserved                                 |          |
|                     | 9     | ADCR_SRC   | 1       | Right Digital Audio interface source          |          |
|                     |       |            |         | 0 = Left ADC data is output on right channel  |          |
|                     |       |            |         | 1 = Right ADC data is output on right channel |          |
|                     | 8     | ADCL_SRC   | 0       | Left Digital Audio interface source           |          |
|                     |       |            |         | 0 = Left ADC data is output on left channel   |          |
|                     |       |            |         | 1 = Right ADC data is output on left channel  |          |
|                     | 7     | DACR_SRC   | 1       | Right DAC Data Source Select                  |          |
|                     |       |            |         | 0 = Right DAC outputs left interface data     |          |
|                     |       |            |         | 1 = Right DAC outputs right interface data    |          |
|                     | 6     | DACL_SRC   | 0       | Left DAC Data Source Select                   |          |
|                     |       |            |         | 0 = Left DAC outputs left interface data      |          |
|                     |       |            |         | 1 = Left DAC outputs right interface data     |          |
|                     | 5     | BCLK_INV   | 0       | BCLK Invert                                   |          |



WM8946 Production Data

| REGISTER | BIT | LABEL     | DEFAULT | DESCRIPTION                                                    | REFER TO |
|----------|-----|-----------|---------|----------------------------------------------------------------|----------|
| ADDRESS  |     |           |         |                                                                |          |
|          |     |           |         | 0 = BCLK not inverted                                          |          |
|          |     |           |         | 1 = BCLK inverted                                              |          |
|          | 4   | LRCLK_INV | 0       | LRCLK Polarity / DSP Mode A-B select.                          |          |
|          |     |           |         |                                                                |          |
|          |     |           |         | Right, left and I2S modes – LRCLK polarity                     |          |
|          |     |           |         | 0 = Not Inverted                                               |          |
|          |     |           |         | 1 = Inverted                                                   |          |
|          |     |           |         | DSP Mode – Mode A-B select                                     |          |
|          |     |           |         | 0 = MSB is available on 2 <sup>nd</sup> BCLK rising edge after |          |
|          |     |           |         | LRCLK rising edge (mode A)                                     |          |
|          |     |           |         | 1 = MSB is available on 1 <sup>st</sup> BCLK rising edge after |          |
|          |     |           |         | LRCLK rising edge (mode B)                                     |          |
|          | 3:2 | WL[1:0]   | 10      | Digital Audio Interface Word Length                            |          |
|          |     |           |         | 00 = 16 bits                                                   |          |
|          |     |           |         | 01 = 20 bits                                                   |          |
|          |     |           |         | 10 = 24 bits                                                   |          |
|          |     |           |         | 11 = 32 bits                                                   |          |
|          |     |           |         | Note – see "Companding" for the selection of 8-bit mode.       |          |
|          | 1:0 | FMT[1:0]  | 10      | Digital Audio Interface Format                                 |          |
|          |     |           |         | 00 = Reserved                                                  |          |
|          |     |           |         | 01 = Left Justified                                            |          |
|          |     |           |         | 10 = I2S format                                                |          |
|          |     |           |         | 11 = DSP/PCM mode                                              |          |

Register 04h Audio Interface

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                                                                 | REFER TO |
|---------------------|-----|-----------|---------|-----------------------------------------------------------------------------|----------|
| R5 (05h)            | 5   | LOOPBACK  | 0       | Digital Loopback Function                                                   |          |
| Companding          |     |           |         | 0 = No loopback                                                             |          |
| control             |     |           |         | 1 = Loopback enabled (ADC data output is directly input to DAC data input). |          |
|                     | 3   | DAC_COMP  | 0       | DAC Companding Enable                                                       |          |
|                     |     |           |         | 0 = Disabled                                                                |          |
|                     |     |           |         | 1 = Enabled                                                                 |          |
|                     | 2   | DAC_COMPM | 0       | DAC Companding Mode                                                         |          |
|                     |     | ODE       |         | $0 = \mu$ -law                                                              |          |
|                     |     |           |         | 1 = A-law                                                                   |          |
|                     | 1   | ADC_COMP  | 0       | ADC Companding Enable                                                       |          |
|                     |     |           |         | 0 = Disabled                                                                |          |
|                     |     |           |         | 1 = Enabled                                                                 |          |
|                     | 0   | ADC_COMPM | 0       | ADC Companding Mode                                                         |          |
|                     |     | ODE       |         | $0 = \mu$ -law                                                              |          |
|                     |     |           |         | 1 = A-law                                                                   |          |

Register 05h Companding control



| REGISTER<br>ADDRESS | BIT   | LABEL         | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|---------------------|-------|---------------|---------|-----------------------------------------------------------------------------------|----------|
| R6 (06h)            | 15    | OSC_CLK_EN    | 0       | Oscillator Enable                                                                 |          |
| Clock Gen           |       | _ A _         |         | 0 = Disabled                                                                      |          |
| control             |       |               |         | 1 = Enabled                                                                       |          |
|                     |       |               |         | This needs to be set when a timeout clock is required                             |          |
|                     |       |               |         | for PGA zero cross or GPIO input detection                                        |          |
|                     | 14:13 | MCLK_PULL     | 00      | MCLK pull-up / pull-down Enable                                                   |          |
|                     |       | [1:0]         |         | 00 = no pull-up or pull-down                                                      |          |
|                     |       |               |         | 01 = pull-down                                                                    |          |
|                     |       |               |         | 10 = pull-up                                                                      |          |
|                     |       |               |         | 11 = reserved                                                                     |          |
|                     | 12    | CLKOUT_SEL    | 0       | CLKOUT Source Select                                                              |          |
|                     |       |               |         | 0 = SYSCLK                                                                        |          |
|                     |       |               |         | 1 = FLL or MCLK (set by SYSCLK_SRC register)                                      |          |
|                     | 11:10 | CLKOUT_DIV    | 00      | CLKOUT Clock divider                                                              |          |
|                     |       | [1:0]         |         | 00 = divide by 1                                                                  |          |
|                     |       |               |         | 01 = divide by 2                                                                  |          |
|                     |       |               |         | 10 = divide by 4                                                                  |          |
|                     |       |               |         | 11 = divide by 8                                                                  |          |
|                     | 9     | SYSCLK_ENA    | 0       | SYSCLK Enable                                                                     |          |
|                     |       | _             |         | 0 = Disabled                                                                      |          |
|                     |       |               |         | 1 = Enabled                                                                       |          |
|                     | 8     | SYSCLK_SRC    | 1       | SYSCLK Source Select                                                              |          |
|                     |       | _             |         | 0 = MCLK                                                                          |          |
|                     |       |               |         | 1 = FLL output                                                                    |          |
|                     | 7:5   | SYSCLK_DIV    | 000     | SYSCLK Clock divider                                                              |          |
|                     |       | [2:0]         |         | (Sets the scaling for either the MCLK or FLL clock                                |          |
|                     |       |               |         | output, depending on SYSCLK_SRC)                                                  |          |
|                     |       |               |         | 000 = divide by 1                                                                 |          |
|                     |       |               |         | 001 = divide by 1.5                                                               |          |
|                     |       |               |         | 010 = divide by 2                                                                 |          |
|                     |       |               |         | 011 = divide by 3                                                                 |          |
|                     |       |               |         | 100 = divide by 4                                                                 |          |
|                     |       |               |         | 101 = divide by 6                                                                 |          |
|                     |       |               |         | 110 = divide by 8                                                                 |          |
|                     |       |               |         | 111 = divide by 12                                                                |          |
|                     | 4     | TOCLK_ENA     | 0       | TOCLK Enabled                                                                     |          |
|                     |       | _             |         | (Enables timeout clock for GPIO level detection, AMU, and PGA zero cross timeout) |          |
|                     |       |               |         | 0 = Disabled                                                                      |          |
|                     |       |               |         | 1 = Enabled                                                                       |          |
|                     | 3:1   | BCLK_DIV[2:0] | 011     | BCLK Frequency (Master mode)                                                      |          |
|                     |       |               |         | 000 = SYSCLK                                                                      |          |
|                     |       |               |         | 001 = SYSCLK / 2                                                                  |          |
|                     |       |               |         | 010 = SYSCLK / 4                                                                  |          |
|                     |       |               |         | 011 = SYSCLK / 8                                                                  |          |
|                     |       |               |         | 100 = SYSCLK / 16                                                                 |          |
|                     |       |               |         | 101 = SYSCLK / 32                                                                 |          |
|                     |       |               |         | 110 = reserved                                                                    |          |
|                     |       |               |         | 111 = reserved                                                                    |          |
|                     | 0     | MSTR          | 0       | Digital Audio Interface Mode select                                               |          |
|                     |       | INIGIA        |         | 0 = Slave mode                                                                    |          |
|                     |       |               |         | 1 = Master mode                                                                   |          |
|                     | L     |               |         | I = IVIGOGO IIIOGO                                                                |          |

Register 06h Clock Gen control



| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                   | REFER TO |
|---------------------|-----|-------------|---------|---------------------------------------------------------------|----------|
| R7 (07h)            | 11  | VMID_FAST_S | 0       | VMID (fast-start) Enable                                      |          |
| Additional          |     | TART        |         | 0 = Disabled                                                  |          |
| control             |     |             |         | 1 = Enabled                                                   |          |
|                     | 10  | VMID_REF_SE | 0       | VMID Source Select                                            |          |
|                     |     | L           |         | 0 = LDO supply (LDOVDD)                                       |          |
|                     |     |             |         | 1 = LDO output (LDOVOUT)                                      |          |
|                     | 9   | VMID_CTRL   | 0       | VMID Ratio control                                            |          |
|                     |     |             |         | Sets the ratio of VMID to the source selected by VMID_REF_SEL |          |
|                     |     |             |         | 0 = 5/11                                                      |          |
|                     |     |             |         | 1 = 1/2                                                       |          |
|                     | 8   | STARTUP_BIA | 0       | Start-Up Bias Enable                                          |          |
|                     |     | S_ENA       |         | 0 = Disabled                                                  |          |
|                     |     |             |         | 1 = Enabled                                                   |          |
|                     | 7   | BIAS_SRC    | 0       | Bias Source select                                            |          |
|                     |     |             |         | 0 = Normal bias                                               |          |
|                     |     |             |         | 1 = Start-Up bias                                             |          |
|                     | 6:5 | VMID_RAMP   | 00      | VMID soft start enable / slew rate control                    |          |
|                     |     | [1:0]       |         | 00 = Disabled                                                 |          |
|                     |     |             |         | 01 = Fast soft start                                          |          |
|                     |     |             |         | 10 = Normal soft start                                        |          |
|                     |     |             |         | 11 = Slow soft start                                          |          |
|                     | 4   | VMID_ENA    | 0       | VMID Enable                                                   |          |
|                     |     |             |         | 0 = Disabled                                                  |          |
|                     |     |             |         | 1 = Enabled                                                   |          |
|                     | 3:0 | SR[3:0]     | 1101    | Audio Sample Rate select                                      |          |
|                     |     |             |         | 0011 = 8kHz                                                   |          |
|                     |     |             |         | 0100 = 11.025kHz                                              |          |
|                     |     |             |         | 0101 = 12kHz                                                  |          |
|                     |     |             |         | 0111 = 16kHz                                                  |          |
|                     |     |             |         | 1000 = 22.05kHz                                               |          |
|                     |     |             |         | 1001 = 24kHz                                                  |          |
|                     |     |             |         | 1011 = 32kHz                                                  |          |
|                     |     |             |         | 1100 = 44.1kHz                                                |          |
|                     |     |             |         | 1101 = 48kHz                                                  |          |

Register 07h Additional control

| REGISTER    | BIT   | LABEL       | DEFAULT | DESCRIPTION                                                                            | REFER TO |
|-------------|-------|-------------|---------|----------------------------------------------------------------------------------------|----------|
| ADDRESS     |       |             |         |                                                                                        |          |
| R8 (08h)    | 12:11 | FLL_CLK_REF | 00      | FLL Clock Reference Divider                                                            |          |
| FLL Control |       | _DIV[1:0]   |         | 00 = MCLK / 1                                                                          |          |
| 1           |       |             |         | 01 = MCLK / 2                                                                          |          |
|             |       |             |         | 10 = MCLK / 4                                                                          |          |
|             |       |             |         | 11 = MCLK / 8                                                                          |          |
|             |       |             |         | MCLK (or other input reference) must be divided down to <=13.5MHz.                     |          |
|             |       |             |         | For lower power operation, the reference clock can be divided down further if desired. |          |



| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT | DESCRIPTION                                                                                                                                | REFER TO |
|---------------------|------|-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------|----------|
|                     | 10:8 | FLL_OUTDIV  | 001     | FOUT clock divider                                                                                                                         |          |
|                     |      | [2:0]       |         | 000 = 2                                                                                                                                    |          |
|                     |      |             |         | 001 = 4                                                                                                                                    |          |
|                     |      |             |         | 010 = 8                                                                                                                                    |          |
|                     |      |             |         | 011 = 16                                                                                                                                   |          |
|                     |      |             |         | 100 = 32                                                                                                                                   |          |
|                     |      |             |         | 101 = 64                                                                                                                                   |          |
|                     |      |             |         | 110 = 128                                                                                                                                  |          |
|                     |      |             |         | 111 = 256                                                                                                                                  |          |
|                     |      |             |         | (FOUT = FVCO / FLL_OUTDIV)                                                                                                                 |          |
|                     | 7:5  | FLL_CTRL_RA | 000     | Frequency of the FLL control block                                                                                                         |          |
|                     |      | TE[2:0]     |         | 000 = FVCO / 1 (Recommended value)                                                                                                         |          |
|                     |      |             |         | 001 = FVCO / 2                                                                                                                             |          |
|                     |      |             |         | 010 = FVCO / 3                                                                                                                             |          |
|                     |      |             |         | 011 = FVCO / 4                                                                                                                             |          |
|                     |      |             |         | 100 = FVCO / 5                                                                                                                             |          |
|                     |      |             |         | 101 = FVCO / 6                                                                                                                             |          |
|                     |      |             |         | 110 = FVCO / 7                                                                                                                             |          |
|                     |      |             |         | 111 = FVCO / 8                                                                                                                             |          |
|                     |      |             |         | Recommended that this register is not changed from default.                                                                                |          |
|                     | 4:2  | FLL_FRATIO  | 000     | FVCO clock divider                                                                                                                         |          |
|                     |      | [2:0]       |         | 000 = 1                                                                                                                                    |          |
|                     |      |             |         | 001 = 2                                                                                                                                    |          |
|                     |      |             |         | 010 = 4                                                                                                                                    |          |
|                     |      |             |         | 011 = 8                                                                                                                                    |          |
|                     |      |             |         | 1XX = 16                                                                                                                                   |          |
|                     |      |             |         | 000 recommended for FREF > 1MHz                                                                                                            |          |
|                     |      |             |         | 100 recommended for FREF < 16kHz                                                                                                           |          |
|                     |      |             |         | 011 recommended for all other cases                                                                                                        |          |
|                     | 1    | FLL_FRAC    | 1       | Fractional enable                                                                                                                          |          |
|                     |      |             |         | 0 = Integer Mode                                                                                                                           |          |
|                     |      |             |         | 1 = Fractional Mode                                                                                                                        |          |
|                     |      |             |         | Integer mode offers reduced power consumption. Fractional mode offers best FLL performance, provided also that N.K is a non-integer value. |          |
|                     | 0    | FLL_ENA     | 0       | FLL Enable                                                                                                                                 |          |
|                     |      |             |         | 0 = Disabled                                                                                                                               |          |
|                     |      |             |         | 1 = Enabled                                                                                                                                |          |

Register 08h FLL Control 1

| REGISTER<br>ADDRESS          | BIT  | LABEL | DEFAULT | DESCRIPTION                              | REFER TO |
|------------------------------|------|-------|---------|------------------------------------------|----------|
| R9 (09h)<br>FLL Control<br>2 | 15:0 |       |         | Fractional multiply for FREF (MSB = 0.5) |          |

Register 09h FLL Control 2



| REGISTER<br>ADDRESS      | BIT  | LABEL         | DEFAULT          | DESCRIPTION                                                                                                                                                  | REFER TO |
|--------------------------|------|---------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| R10 (0Ah)<br>FLL Control | 14:5 | FLL_N[9:0]    | 00_0000_1<br>000 | Integer multiply for FREF (LSB = 1)                                                                                                                          |          |
| 3                        | 3:0  | FLL_GAIN[3:0] | 0100             | Gain applied to error  0000 = x 1 (Recommended value)  0001 = x 2  0010 = x 4  0011 = x 8  0100 = x 16  0101 = x 32  0110 = x 64  0111 = x 128  1000 = x 256 |          |
|                          |      |               |                  | Recommended that this register is not changed from default.                                                                                                  |          |

Register 0Ah FLL Control 3

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                                                | REFER TO |
|---------------------|-----|-----------|---------|------------------------------------------------------------|----------|
| R11 (0Bh)           | 0   | MODE GPIO | 0       | CIFMODE/GPIO3 pin configuration                            |          |
| GPIO Config         | -   | WODE_GFIO | 0       | 0 = Pin configured as CIFMODE                              |          |
| Or to coming        |     |           |         | 1 = Pin configured as GPIO3                                |          |
|                     |     |           |         | Note – when this bit is set to 1, it is latched and cannot |          |
|                     |     |           |         | be reset until Power-Off or Software Reset.                |          |

Register 0Bh GPIO Config

| REGISTER<br>ADDRESS | BIT   | LABEL         | DEFAULT | DESCRIPTION                                                                                       | REFER TO |
|---------------------|-------|---------------|---------|---------------------------------------------------------------------------------------------------|----------|
| R12 (0Ch)           | 15    | GP1 DIR       | 1       | GPIO1 Pin Direction                                                                               |          |
| GPIO1               | 15    | GP1_DIK       | ı       |                                                                                                   |          |
| Control             |       |               |         | 0 = Output                                                                                        |          |
|                     | 1110  | 004 000 000   |         | 1 = Input                                                                                         |          |
|                     | 14:13 | GP1_PULL[1:0] | 00      | GPIO1 pull-up / pull-down Enable                                                                  |          |
|                     |       |               |         | 00 = no pull-up or pull-down                                                                      |          |
|                     |       |               |         | 01 = pull-down                                                                                    |          |
|                     |       |               |         | 10 = pull-up                                                                                      |          |
|                     |       |               |         | 11 = reserved                                                                                     |          |
|                     | 12    | GP1_INT_MOD   | 0       | GPIO1 Interrupt Mode                                                                              |          |
|                     |       | E             |         | 0 = GPIO interrupt is rising edge triggered (if GP1_POL=1)                                        |          |
|                     |       |               |         | 1 = GPIO interrupt is triggered on rising and falling edges                                       |          |
|                     | 10    | GP1_POL       | 0       | GPIO1 Polarity Select                                                                             |          |
|                     |       |               |         | 0 = Non-inverted                                                                                  |          |
|                     |       |               |         | 1 = Inverted                                                                                      |          |
|                     | 5     | GP1_LVL       | 0       | GPIO1 level. Write to this bit to set a GPIO output. Read from this bit to read GPIO input level. |          |
|                     |       |               |         | When GP1_POL is set, the register contains the opposite logic level to the external pin.          |          |



| REGISTER | BIT | LABEL       | DEFAULT | DESCRIPTION                    | REFER TO |
|----------|-----|-------------|---------|--------------------------------|----------|
| ADDRESS  |     |             |         |                                |          |
|          | 3:0 | GP1_FN[3:0] | 0000    | GPIO1 Pin Function             |          |
|          |     |             |         | 0000 = Logic Level Input       |          |
|          |     |             |         | 0001 = Edge Detection Input    |          |
|          |     |             |         | 0010 = CLKOUT output           |          |
|          |     |             |         | 0011 = Interrupt (IRQ) output  |          |
|          |     |             |         | 0100 = Reserved                |          |
|          |     |             |         | 0101 = Reserved                |          |
|          |     |             |         | 0110 = Reserved                |          |
|          |     |             |         | 0111 = Temperature flag output |          |
|          |     |             |         | 1000 = Reserved                |          |
|          |     |             |         | 1001 = DMICCLK output          |          |
|          |     |             |         | 1010 = Logic Level output      |          |
|          |     |             |         | 1011 = LDO_UV output           |          |
|          |     |             |         | 1100 = Reserved                |          |
|          |     |             |         | 1101 = Reserved                |          |
|          |     |             |         | 1110 = Reserved                |          |
|          |     |             |         | 1111 = Reserved                |          |

Register 0Ch GPIO1 Control

| REGISTER           | BIT   | LABEL            | DEFAULT | DESCRIPTION                                                                                         | REFER TO |
|--------------------|-------|------------------|---------|-----------------------------------------------------------------------------------------------------|----------|
| ADDRESS            | 45    | ODO DID          | 4       | ODIOO Din Discotion                                                                                 |          |
| R13 (0Dh)<br>GPIO2 | 15    | GP2_DIR          | 1       | GPIO2 Pin Direction                                                                                 |          |
| Control            |       |                  |         | 0 = Output                                                                                          |          |
| 00.11.0.           |       |                  |         | 1 = Input                                                                                           |          |
|                    | 14:13 | GP2_PULL[1:0]    | 00      | GPIO2 pull-up / pull-down Enable                                                                    |          |
|                    |       |                  |         | 00 = no pull-up or pull-down                                                                        |          |
|                    |       |                  |         | 01 = pull-down                                                                                      |          |
|                    |       |                  |         | 10 = pull-up                                                                                        |          |
|                    | 4.0   | 000 000          |         | 11 = reserved                                                                                       |          |
|                    | 12    | GP2_INT_MOD<br>E | 0       | GPIO2 Interrupt Mode                                                                                |          |
|                    |       | E                |         | 0 = GPIO interrupt is rising edge triggered (if GP2_POL=0) or falling edge triggered (if GP2_POL=1) |          |
|                    |       |                  |         | 1 = GPIO interrupt is triggered on rising and falling                                               |          |
|                    |       |                  |         | edges                                                                                               |          |
|                    | 10    | GP2_POL          | 0       | GPIO2 Polarity Select                                                                               |          |
|                    |       |                  |         | 0 = Non-inverted                                                                                    |          |
|                    |       |                  |         | 1 = Inverted                                                                                        |          |
|                    | 5     | GP2_LVL          | 0       | GPIO2 level. Write to this bit to set a GPIO output.                                                |          |
|                    |       |                  |         | Read from this bit to read GPIO input level.                                                        |          |
|                    |       |                  |         | When GP2_POL is set, the register contains the                                                      |          |
|                    |       |                  |         | opposite logic level to the external pin.                                                           |          |
|                    | 3:0   | GP2_FN[3:0]      | 0000    | GPIO2 Pin Function                                                                                  |          |
|                    |       |                  |         | 0000 = Logic Level Input                                                                            |          |
|                    |       |                  |         | 0001 = Edge Detection Input                                                                         |          |
|                    |       |                  |         | 0010 = CLKOUT output                                                                                |          |
|                    |       |                  |         | 0011 = Interrupt (IRQ) output                                                                       |          |
|                    |       |                  |         | 0100 = Reserved                                                                                     |          |
|                    |       |                  |         | 0101 = Reserved                                                                                     |          |
|                    |       |                  |         | 0110 = Reserved                                                                                     |          |
|                    |       |                  |         | 0111 = Temperature flag output<br>1000 = Reserved                                                   |          |
|                    |       |                  |         | 1000 - Reserved<br>1001 = DMICCLK output                                                            |          |
|                    |       |                  |         | 1010 = Logic Level output                                                                           |          |
|                    |       |                  |         | 1011 = LDO_UV output                                                                                |          |
|                    |       |                  |         | 1100 = Reserved                                                                                     |          |
|                    |       |                  |         | 1101 = Reserved                                                                                     |          |



WM8946 Production Data

| REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION     | REFER TO |
|---------------------|-----|-------|---------|-----------------|----------|
|                     |     |       |         | 1110 = Reserved |          |
|                     |     |       |         | 1111 = Reserved |          |

Register 0Dh GPIO2 Control

| REGISTER         | BIT   | LABEL         | DEFAULT | DESCRIPTION                                                                                          | REFER TO |
|------------------|-------|---------------|---------|------------------------------------------------------------------------------------------------------|----------|
| ADDRESS          |       |               |         |                                                                                                      |          |
| R14 (0Eh)        | 15    | GP3_DIR       | 1       | GPIO3 Pin Direction                                                                                  |          |
| GPIO3<br>Control |       |               |         | 0 = Output                                                                                           |          |
| Control          |       |               |         | 1 = Input                                                                                            |          |
|                  | 14:13 | GP3_PULL[1:0] | 10      | GPIO3 pull-up / pull-down Enable                                                                     |          |
|                  |       |               |         | 00 = no pull-up or pull-down                                                                         |          |
|                  |       |               |         | 01 = pull-down                                                                                       |          |
|                  |       |               |         | 10 = pull-up                                                                                         |          |
|                  |       |               |         | 11 = reserved                                                                                        |          |
|                  | 12    | GP3_INT_MOD   | 0       | GPIO3 Interrupt Mode                                                                                 |          |
|                  |       | E             |         | 0 = GPIO interrupt is rising edge triggered (if GP3_POL=1) or falling edge triggered (if GP3_POL=1)  |          |
|                  |       |               |         | 1 = GPIO interrupt is triggered on rising and falling                                                |          |
|                  |       |               |         | edges                                                                                                |          |
|                  | 10    | GP3_POL       | 0       | GPIO3 Polarity Select                                                                                |          |
|                  |       |               |         | 0 = Non-inverted                                                                                     |          |
|                  |       |               |         | 1 = Inverted                                                                                         |          |
|                  | 5     | GP3_LVL       | 0       | GPIO3 level. Write to this bit to set a GPIO output.<br>Read from this bit to read GPIO input level. |          |
|                  |       |               |         | When GP3_POL is set, the register contains the                                                       |          |
|                  |       |               |         | opposite logic level to the external pin.                                                            |          |
|                  | 3:0   | GP3_FN[3:0]   | 0000    | GPIO3 Pin Function                                                                                   |          |
|                  |       |               |         | 0000 = Logic Level Input                                                                             |          |
|                  |       |               |         | 0001 = Edge Detection Input                                                                          |          |
|                  |       |               |         | 0010 = CLKOUT output                                                                                 |          |
|                  |       |               |         | 0011 = Interrupt (IRQ) output                                                                        |          |
|                  |       |               |         | 0100 = Reserved                                                                                      |          |
|                  |       |               |         | 0101 = Reserved                                                                                      |          |
|                  |       |               |         | 0110 = Reserved                                                                                      |          |
|                  |       |               |         | 0111 = Temperature flag output                                                                       |          |
|                  |       |               |         | 1000 = Reserved                                                                                      |          |
|                  |       |               |         | 1001 = DMICCLK output                                                                                |          |
|                  |       |               |         | 1010 = Logic Level output                                                                            |          |
|                  |       |               |         | 1011 = LDO_UV output                                                                                 |          |
|                  |       |               |         | 1100 = Reserved                                                                                      |          |
|                  |       |               |         | 1101 = Reserved                                                                                      |          |
|                  |       |               |         | 1110 = Reserved                                                                                      |          |
|                  |       |               |         | 1111 = Reserved                                                                                      |          |

Register 0Eh GPIO3 Control

| REGISTER<br>ADDRESS | BIT   | LABEL         | DEFAULT | DESCRIPTION                                                                                         | REFER TO |
|---------------------|-------|---------------|---------|-----------------------------------------------------------------------------------------------------|----------|
| R15 (0Fh)           | 15    | GP4_DIR       | 1       | GPIO4 Pin Direction                                                                                 |          |
| GPIO4               |       |               |         | 0 = Output                                                                                          |          |
| Control             |       |               |         | 1 = Input                                                                                           |          |
|                     | 14:13 | GP4_PULL[1:0] | 00      | GPIO4 pull-up / pull-down Enable                                                                    |          |
|                     |       |               |         | 00 = no pull-up or pull-down                                                                        |          |
|                     |       |               |         | 01 = pull-down                                                                                      |          |
|                     |       |               |         | 10 = pull-up                                                                                        |          |
|                     |       |               |         | 11 = reserved                                                                                       |          |
|                     | 12    | GP4_INT_MOD   | 0       | GPIO4 Interrupt Mode                                                                                |          |
|                     |       | E             |         | 0 = GPIO interrupt is rising edge triggered (if GP4_POL=1) or falling edge triggered (if GP4_POL=1) |          |
|                     |       |               |         | 1 = GPIO interrupt is triggered on rising and falling edges                                         |          |
|                     | 10    | GP4_POL       | 0       | GPIO4 Polarity Select                                                                               |          |
|                     |       |               |         | 0 = Non-inverted                                                                                    |          |
|                     |       |               |         | 1 = Inverted                                                                                        |          |
|                     | 5     | GP4_LVL       | 0       | GPIO4 level. Write to this bit to set a GPIO output. Read from this bit to read GPIO input level.   |          |
|                     |       |               |         | When GP4_POL is set, the register contains the                                                      |          |
|                     |       |               |         | opposite logic level to the external pin.                                                           |          |
|                     | 3:0   | GP4_FN[3:0]   | 0000    | GPIO4 Pin Function                                                                                  |          |
|                     |       |               |         | 0000 = Logic Level Input                                                                            |          |
|                     |       |               |         | 0001 = Edge Detection Input                                                                         |          |
|                     |       |               |         | 0010 = CLKOUT output                                                                                |          |
|                     |       |               |         | 0011 = Interrupt (IRQ) output                                                                       |          |
|                     |       |               |         | 0100 = Reserved                                                                                     |          |
|                     |       |               |         | 0101 = Reserved                                                                                     |          |
|                     |       |               |         | 0110 = Reserved                                                                                     |          |
|                     |       |               |         | 0111 = Temperature flag output                                                                      |          |
|                     |       |               |         | 1000 = Reserved                                                                                     |          |
|                     |       |               |         | 1001 = DMICCLK output                                                                               |          |
|                     |       |               |         | 1010 = Logic Level output                                                                           |          |
|                     |       |               |         | 1011 = LDO_UV output                                                                                |          |
|                     |       |               |         | 1100 = Reserved                                                                                     |          |
|                     |       |               |         | 1101 = Reserved                                                                                     |          |
|                     |       |               |         | 1110 = Reserved                                                                                     |          |
|                     |       |               |         | 1111 = Reserved                                                                                     |          |

Register 0Fh GPIO4 Control

| REGISTER   | BIT | LABEL      | DEFAULT | DESCRIPTION                                                            | REFER TO |
|------------|-----|------------|---------|------------------------------------------------------------------------|----------|
| ADDRESS    |     |            |         |                                                                        |          |
| R16 (10h)  | 15  | TEMP_INT   | 0       | Thermal Interrupt status                                               |          |
| System     |     |            |         | 0 = Thermal interrupt not set                                          |          |
| Interrupts |     |            |         | 1 = Thermal interrupt set                                              |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |
|            | 14  | GP4_INT    | 0       | GPIO4 Interrupt status                                                 |          |
|            |     |            |         | 0 = GPIO4 interrupt not set                                            |          |
|            |     |            |         | 1 = GPIO4 interrupt set                                                |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |
|            | 13  | GP3_INT    | 0       | GPIO3 Interrupt status                                                 |          |
|            |     |            |         | 0 = GPIO3 interrupt not set                                            |          |
|            |     |            |         | 1 = GPIO3 interrupt set                                                |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |
|            | 12  | GP2_INT    | 0       | GPIO2 Interrupt status                                                 |          |
|            |     |            |         | 0 = GPIO2 interrupt not set                                            |          |
|            |     |            |         | 1 = GPIO2 interrupt set                                                |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |
|            | 11  | GP1_INT    | 0       | GPIO1 Interrupt status                                                 |          |
|            |     |            |         | 0 = GPIO1 interrupt not set                                            |          |
|            |     |            |         | 1 = GPIO1 interrupt set                                                |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |
|            | 0   | LDO_UV_INT | 0       | LDO Undervoltage Interrupt                                             |          |
|            |     |            |         | 0 = LDO Undervoltage interrupt not set                                 |          |
|            |     |            |         | 1 = LDO Undervoltage interrupt set                                     |          |
|            |     |            |         | This bit is latched when set; it is cleared when the register is Read. |          |

Register 10h System Interrupts

| REGISTER     | BIT | LABEL      | DEFAULT | DESCRIPTION             | REFER TO |
|--------------|-----|------------|---------|-------------------------|----------|
| ADDRESS      |     |            |         |                         |          |
| R17 (11h)    | 15  | TEMP_STS   | 0       | Thermal Sensor status   |          |
| Status Flags |     |            |         | 0 = Normal              |          |
|              |     |            |         | 1 = Overtemperature     |          |
|              | 0   | LDO_UV_STS | 0       | LDO Undervoltage status |          |
|              |     |            |         | 0 = Normal              |          |
|              |     |            |         | 1 = Undervoltage        |          |

Register 11h Status Flags

| REGISTER   | BIT | LABEL  | DEFAULT | DESCRIPTION              | REFER TO |
|------------|-----|--------|---------|--------------------------|----------|
| ADDRESS    |     |        |         |                          |          |
| R18 (12h)  | 0   | IM_IRQ | 1       | IRQ (GPIO output) Mask   |          |
| IRQ Config |     |        |         | 0 = Normal               |          |
|            |     |        |         | 1 = IRQ output is masked |          |

Register 12h IRQ Config

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                | REFER TO |
|---------------------|-----|-------------|---------|--------------------------------------------|----------|
| R19 (13h)           | 15  | IM_TEMP_INT | 0       | Interrupt mask for thermal status          |          |
| System              |     |             |         | 0 = Not masked                             |          |
| Interrupts          |     |             |         | 1 = Masked                                 |          |
| Mask                | 14  | IM_GP4_INT  | 0       | Interrupt mask for GPIO4                   |          |
|                     |     |             |         | 0 = Not masked                             |          |
|                     |     |             |         | 1 = Masked                                 |          |
|                     | 13  | IM_GP3_INT  | 0       | Interrupt mask for GPIO3                   |          |
|                     |     |             |         | 0 = Not masked                             |          |
|                     |     |             |         | 1 = Masked                                 |          |
|                     | 12  | IM_GP2_INT  | 0       | Interrupt mask for GPIO2                   |          |
|                     |     |             |         | 0 = Not masked                             |          |
|                     |     |             |         | 1 = Masked                                 |          |
|                     | 11  | IM_GP1_INT  | 0       | Interrupt mask for GPIO1                   |          |
|                     |     |             |         | 0 = Not masked                             |          |
|                     |     |             |         | 1 = Masked                                 |          |
|                     | 0   | IM_LDO_UV_I | 0       | Interrupt mask for LDO Undervoltage status |          |
|                     |     | NT          |         | 0 = Not masked                             |          |
|                     |     |             |         | 1 = Masked                                 |          |

Register 13h System Interrupts Mask

| REGISTER             | BIT | LABEL     | DEFAULT | DESCRIPTION                                                      | REFER TO |
|----------------------|-----|-----------|---------|------------------------------------------------------------------|----------|
| ADDRESS              |     |           |         |                                                                  |          |
| R20 (14h)            | 2   | SPI_OD    | 0       | SDOUT pin configuration                                          |          |
| Control<br>Interface |     |           |         | (applies to 3-wire and 4-wire mode only)0 = SDOUT output is CMOS |          |
|                      |     |           |         | 1 = SDOUT output is open drain                                   |          |
|                      | 1   | SPI_4WIRE | 1       | SPI control mode select                                          |          |
|                      |     |           |         | 0 = 3-wire using bidirectional SDA                               |          |
|                      |     |           |         | 1 = 4-wire using SDOUT                                           |          |
|                      | 0   | AUTO_INC  | 0       | Enables address auto-increment                                   |          |
|                      |     |           |         | (applies to 2-wire / I2C mode only)                              |          |
|                      |     |           |         | 0 = Disabled                                                     |          |
|                      |     |           |         | 1 = Enabled                                                      |          |

Register 14h Control Interface

| REGISTER    | BIT | LABEL       | DEFAULT | DESCRIPTION                        | REFER TO |
|-------------|-----|-------------|---------|------------------------------------|----------|
| ADDRESS     |     |             |         |                                    |          |
| R21 (15h)   | 8   | DAC_MUTEAL  | 1       | DAC Digital Mute for All Channels: |          |
| DAC Control |     | L           |         | 0 = Disable Mute                   |          |
| 1           |     |             |         | 1 = Enable Mute on all channels    |          |
|             | 4   | DAC_AUTOMU  | 1       | DAC Auto-Mute Control              |          |
|             |     | TE          |         | 0 = Disabled                       |          |
|             |     |             |         | 1 = Enabled                        |          |
|             | 1   | DACR_DATIN  | 0       | Right DAC Invert                   |          |
|             |     | V           |         | 0 = Right DAC output not inverted  |          |
|             |     |             |         | 1 = Right DAC output inverted      |          |
|             | 0   | DACL_DATINV | 0       | Left DAC Invert                    |          |
|             |     |             |         | 0 = Left DAC output not inverted   |          |
|             |     |             |         | 1 = Left DAC output inverted       |          |

Register 15h DAC Control 1

| REGISTER<br>ADDRESS | BIT | LABEL      | DEFAULT | DESCRIPTION                        | REFER TO |
|---------------------|-----|------------|---------|------------------------------------|----------|
| R22 (16h)           | 4   | DAC_VOL_RA | 1       | DAC Volume Ramp control            |          |
| DAC Control         |     | MP         |         | 0 = Disabled                       |          |
| 2                   |     |            |         | 1 = Enabled                        |          |
|                     | 0   | DAC_SB_FLT | 0       | Selects DAC filter characteristics |          |
|                     |     |            |         | 0 = Normal mode                    |          |
|                     |     |            |         | 1 = Sloping stopband mode          |          |

Register 16h DAC Control 2

| REGISTER                | BIT | LABEL     | DEFAULT   | DESCRIPTION                                                                               | REFER TO |
|-------------------------|-----|-----------|-----------|-------------------------------------------------------------------------------------------|----------|
| ADDRESS                 |     |           |           |                                                                                           |          |
| R23 (17h)               | 12  | DAC_VU    | 0         | DAC Volume Update                                                                         |          |
| Left DAC<br>digital Vol |     |           |           | Writing a 1 to this bit will cause Left and Right DAC volume to be updated simultaneously |          |
|                         | 8   | DACL_MUTE | 0         | Left DAC Digital Mute                                                                     |          |
|                         |     |           |           | 0 = Disable Mute                                                                          |          |
|                         |     |           |           | 1 = Enable Mute                                                                           |          |
|                         | 7:0 | DACL_VOL  | 1100_0000 | Left DAC Digital Volume                                                                   |          |
|                         |     | [7:0]     |           | 0000_0000 = mute                                                                          |          |
|                         |     |           |           | 0000_0001 = -71.625dB                                                                     |          |
|                         |     |           |           | 0000_0010 = -71.250dB                                                                     |          |
|                         |     |           |           |                                                                                           |          |
|                         |     |           |           | 1100_0000 = 0dB                                                                           |          |
|                         |     |           |           |                                                                                           |          |
|                         |     |           |           | 1111_1111 = +23.625dB                                                                     |          |

Register 17h Left DAC digital Vol

Production Data \_\_\_\_\_\_ **WM8946** 

| REGISTER<br>ADDRESS   | BIT | LABEL     | DEFAULT   | DESCRIPTION                                                                               | REFER TO |
|-----------------------|-----|-----------|-----------|-------------------------------------------------------------------------------------------|----------|
| R24 (18h)             | 12  | DAC_VU    | 0         | DAC Volume Update                                                                         |          |
| Right DAC digital Vol |     | _         |           | Writing a 1 to this bit will cause Left and Right DAC volume to be updated simultaneously |          |
|                       | 8   | DACR_MUTE | 0         | Right DAC Digital Mute                                                                    |          |
|                       |     |           |           | 0 = Disable Mute                                                                          |          |
|                       |     |           |           | 1 = Enable Mute                                                                           |          |
|                       | 7:0 | DACR_VOL  | 1100_0000 | Right DAC volume control                                                                  |          |
|                       |     | [7:0]     |           | 0000_0000 = mute                                                                          |          |
|                       |     |           |           | 0000_0001 = -71.625dB                                                                     |          |
|                       |     |           |           | 0000_0010 = -71.250dB                                                                     |          |
|                       |     |           |           |                                                                                           |          |
|                       |     |           |           | 1100_0000 = 0dB                                                                           |          |
|                       |     |           |           |                                                                                           |          |
|                       |     |           |           | 1111_1111 = +23.625dB                                                                     |          |

Register 18h Right DAC digital Vol

| REGISTER    | BIT | LABEL       | DEFAULT | DESCRIPTION                       | REFER TO |
|-------------|-----|-------------|---------|-----------------------------------|----------|
| ADDRESS     |     |             |         |                                   |          |
| R25 (19h)   | 8   | ADC_MUTEAL  | 1       | ADC Digital Mute for All Channels |          |
| ADC Control |     | L           |         | 0 = Disable Mute                  |          |
| 1           |     |             |         | 1 = Enable Mute on all channels   |          |
|             | 1   | ADCR_DATIN  | 0       | Right ADC Invert                  |          |
|             |     | V           |         | 0 = Right ADC output not inverted |          |
|             |     |             |         | 1 = Right ADC output inverted     |          |
|             | 0   | ADCL_DATINV | 0       | Left ADC Invert                   |          |
|             |     |             |         | 0 = Left ADC output not inverted  |          |
|             |     |             |         | 1 = Left ADC output inverted      |          |

Register 19h ADC Control 1

| REGISTER<br>ADDRESS           | BIT | LABEL                | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                               | REFER TO |
|-------------------------------|-----|----------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| R26 (1Ah)<br>ADC Control<br>2 | 2:1 | ADC_HPF_CU<br>T[1:0] | 00      | High pass filter configuration.  00 = 1 <sup>st</sup> order HPF (fc=4Hz at fs=48kHz)  01 = 2 <sup>nd</sup> order HPF (fc=122Hz at fs=48kHz)  10 = 2 <sup>nd</sup> order HPF (fc=153Hz at fs=48kHz)  11 = 2 <sup>nd</sup> order HPF (fc=196Hz at fs=48kHz) | Table 11 |
|                               | 0   | ADC_HPF              | 0       | ADC Digital High Pass Filter Enable 0 = Disabled 1 = Enabled                                                                                                                                                                                              |          |

Register 1Ah ADC Control 2

| REGISTER<br>ADDRESS     | BIT | LABEL     | DEFAULT   | DESCRIPTION                                                                               | REFER TO |
|-------------------------|-----|-----------|-----------|-------------------------------------------------------------------------------------------|----------|
| R27 (1Bh)               | 12  | ADC_VU    | 0         | ADC Volume Update                                                                         |          |
| Left ADC<br>Digital Vol |     |           |           | Writing a 1 to this bit will cause Left and Right ADC volume to be updated simultaneously |          |
|                         | 8   | ADCL_MUTE | 0         | Left ADC Digital Mute                                                                     |          |
|                         |     |           |           | 0 = Disable Mute                                                                          |          |
|                         |     |           |           | 1 = Enable Mute                                                                           |          |
|                         | 7:0 | ADCL_VOL  | 1100_0000 | Left ADC Digital Volume                                                                   |          |
|                         |     | [7:0]     |           | 0000_0000 = mute                                                                          |          |
|                         |     |           |           | 0000_0001 = -71.625dB                                                                     |          |
|                         |     |           |           | 0000_0010 = -71.250dB                                                                     |          |
|                         |     |           |           |                                                                                           |          |
|                         |     |           |           | 1100_0000 = 0dB                                                                           |          |
|                         |     |           |           |                                                                                           |          |
|                         |     |           |           | 1111_1111 = +23.625dB                                                                     |          |

Register 1Bh Left ADC Digital Vol

| REGISTER                 | BIT | LABEL     | DEFAULT   | DESCRIPTION                                                                               | REFER TO |
|--------------------------|-----|-----------|-----------|-------------------------------------------------------------------------------------------|----------|
| ADDRESS                  |     |           |           |                                                                                           |          |
| R28 (1Ch)                | 12  | ADC_VU    | 0         | ADC Volume Update                                                                         |          |
| Right ADC<br>Digital Vol |     |           |           | Writing a 1 to this bit will cause Left and Right ADC volume to be updated simultaneously |          |
|                          | 8   | ADCR_MUTE | 0         | Right ADC Digital Mute                                                                    |          |
|                          |     |           |           | 0 = Disable Mute                                                                          |          |
|                          |     |           |           | 1 = Enable Mute                                                                           |          |
|                          | 7:0 | ADCR_VOL  | 1100_0000 | Right ADC Digital Volume                                                                  |          |
|                          |     | [7:0]     |           | 0000_0000 = mute                                                                          |          |
|                          |     |           |           | 0000_0001 = -71.625dB                                                                     |          |
|                          |     |           |           | 0000_0010 = -71.250dB                                                                     |          |
|                          |     |           |           |                                                                                           |          |
|                          |     |           |           | 1100_0000 = 0dB                                                                           |          |
|                          |     |           |           |                                                                                           |          |
|                          |     |           |           | 1111_1111 = +23.625dB                                                                     |          |

Register 1Ch Right ADC Digital Vol

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION              | REFER TO |
|---------------------|-----|-------------|---------|--------------------------|----------|
| R29 (1Dh)           | 8   | DRC_NG_ENA  | 0       | DRC Noise Gate Enable    |          |
| DRC Control         |     |             |         | 0 = Disabled             |          |
| 1                   |     |             |         | 1 = Enabled              |          |
|                     | 7   | DRC_ENA     | 0       | DRC Enable               |          |
|                     |     |             |         | 0 = Disabled             |          |
|                     |     |             |         | 1 = Enabled              |          |
|                     | 2   | DRC_QR      | 1       | DRC Quick-release Enable |          |
|                     |     |             |         | 0 = Disabled             |          |
|                     |     |             |         | 1 = Enabled              |          |
|                     | 1   | DRC_ANTICLI | 1       | DRC Anti-clip Enable     |          |
|                     |     | Р           |         | 0 = Disabled             |          |
|                     |     |             |         | 1 = Enabled              |          |

Register 1Dh DRC Control 1



| REGISTER<br>ADDRESS | BIT  | LABEL                | DEFAULT | DESCRIPTION                                              | REFER TO |
|---------------------|------|----------------------|---------|----------------------------------------------------------|----------|
| R30 (1Eh)           | 12:9 | DRC_NG_MIN           | 0110    | Minimum gain the DRC can use to attenuate audio          |          |
| DRC Control<br>2    |      | GAIN[3:0]            |         | signals when the noise gate is active.                   |          |
| 2                   |      |                      |         | 0000 = -36dB                                             |          |
|                     |      |                      |         | 0001 = -30dB                                             |          |
|                     |      |                      |         | 0010 = -24dB                                             |          |
|                     |      |                      |         | 0011 = -18dB                                             |          |
|                     |      |                      |         | 0100 = -12dB                                             |          |
|                     |      |                      |         | 0101 = -6dB                                              |          |
|                     |      |                      |         | 0110 = 0dB                                               |          |
|                     |      |                      |         | 0111 = 6dB                                               |          |
|                     |      |                      |         | 1000 = 12dB                                              |          |
|                     |      |                      |         | 1001 = 18dB                                              |          |
|                     |      |                      |         | 1010 = 24dB                                              |          |
|                     |      |                      |         | 1011 = 30dB                                              |          |
|                     |      |                      |         | 1100 = 36dB                                              |          |
|                     |      |                      |         | 1101 to 1111 = Reserved                                  |          |
|                     | 4:2  | DRC_MINGAIN          | 001     | Minimum gain the DRC can use to attenuate audio          |          |
|                     |      | [2:0]                |         | signals                                                  |          |
|                     |      |                      |         | 000 = 0dB                                                |          |
|                     |      |                      |         | 001 = -12dB (default)                                    |          |
|                     |      |                      |         | 010 = -18dB                                              |          |
|                     |      |                      |         | 011 = -24dB                                              |          |
|                     |      |                      |         | 100 = -36dB                                              |          |
|                     |      |                      |         | 101 = Reserved                                           |          |
|                     |      |                      |         | 11X = Reserved                                           |          |
|                     | 1:0  | DRC_MAXGAI<br>N[1:0] | 01      | Maximum gain the DRC can use to boost audio signals (dB) |          |
|                     |      |                      |         | 00 = 12dB                                                |          |
|                     |      |                      |         | 01 = 18dB                                                |          |
|                     |      |                      |         | 10 = 24dB                                                |          |
|                     |      |                      |         | 11 = 36dB                                                |          |

Register 1Eh DRC Control 2

| REGISTER    | BIT | LABEL        | DEFAULT | DESCRIPTION                    | REFER TO |
|-------------|-----|--------------|---------|--------------------------------|----------|
| ADDRESS     |     |              |         |                                |          |
| R31 (1Fh)   | 7:4 | DRC_ATK[3:0] | 0100    | Gain attack rate (seconds/6dB) |          |
| DRC Control |     |              |         | 0000 = Reserved                |          |
| 3           |     |              |         | 0001 = 181us                   |          |
|             |     |              |         | 0010 = 363us                   |          |
|             |     |              |         | 0011 = 726us                   |          |
|             |     |              |         | 0100 = 1.45ms                  |          |
|             |     |              |         | 0101 = 2.9ms                   |          |
|             |     |              |         | 0110 = 5.8ms                   |          |
|             |     |              |         | 0111 = 11.6ms                  |          |
|             |     |              |         | 1000 = 23.2ms                  |          |
|             |     |              |         | 1001 = 46.4ms                  |          |
|             |     |              |         | 1010 = 92.8ms                  |          |
|             |     |              |         | 1011 = 185.6ms                 |          |
|             |     |              |         | 1100-1111 = Reserved           |          |
|             | 3:0 | DRC_DCY[3:0] | 0010    | Gain decay rate (seconds/6dB)  |          |
|             |     |              |         | 0000 = 186ms                   |          |
|             |     |              |         | 0001 = 372ms                   |          |
|             |     |              |         | 0010 = 743ms                   |          |
|             |     |              |         | 0011 = 1.49s                   |          |
|             |     |              |         | 0100 = 2.97s                   |          |
|             |     |              |         | 0101 = 5.94s                   |          |
|             |     |              |         | 0110 = 11.89s                  |          |
|             |     |              |         | 0111 = 23.78s                  |          |
|             |     |              |         | 1000 = 47.56s                  |          |
|             |     |              |         | 1001-1111 = Reserved           |          |

Register 1Fh DRC Control 3

| REGISTER    | BIT  | LABEL       | DEFAULT | DESCRIPTION                                             | REFER TO |
|-------------|------|-------------|---------|---------------------------------------------------------|----------|
| ADDRESS     |      |             |         |                                                         |          |
| R32 (20h)   | 12:8 | DRC_KNEE2_I | 0_0000  | Input signal level at the Noise Gate threshold 'Knee2'. |          |
| DRC Control |      | P[4:0]      |         | 00000 = -36dB                                           |          |
| 4           |      |             |         | 00001 = -37.5dB                                         |          |
|             |      |             |         | 00010 = -39dB                                           |          |
|             |      |             |         | (-1.5dB steps)                                          |          |
|             |      |             |         | 11110 = -81dB                                           |          |
|             |      |             |         | 11111 = -82.5dB                                         |          |
|             |      |             |         | Only applicable when DRC_NG_ENA = 1.                    |          |
|             | 7:2  | DRC_KNEE_IP | 00_0000 | Input signal level at the Compressor 'Knee1'.           |          |
|             |      | [5:0]       |         | 000000 = 0dB                                            |          |
|             |      |             |         | 000001 = -0.75dB                                        |          |
|             |      |             |         | 000010 = -1.5dB                                         |          |
|             |      |             |         | (-0.75dB steps)                                         |          |
|             |      |             |         | 111100 = -45dB                                          |          |
|             |      |             |         | 111101 = Reserved                                       |          |
|             |      |             |         | 11111X = Reserved                                       |          |

Register 20h DRC Control 4



| REGISTER    | BIT  | LABEL      | DEFAULT | DESCRIPTION                                        | REFER TO |
|-------------|------|------------|---------|----------------------------------------------------|----------|
| ADDRESS     |      |            |         |                                                    |          |
| R33 (21h)   | 13   | DRC_KNEE2_ | 0       | DRC_KNEE2_OP Enable                                |          |
| DRC Control |      | OP_ENA     |         | 0 = Disabled                                       |          |
| 5           |      |            |         | 1 = Enabled                                        |          |
|             | 12:8 | DRC_KNEE2_ | 0_0000  | Output signal at the Noise Gate threshold 'Knee2'. |          |
|             |      | OP[4:0]    |         | 00000 = -30dB                                      |          |
|             |      |            |         | 00001 = -31.5dB                                    |          |
|             |      |            |         | 00010 = -33dB                                      |          |
|             |      |            |         | (-1.5dB steps)                                     |          |
|             |      |            |         | 11110 = -75dB                                      |          |
|             |      |            |         | 11111 = -76.5dB                                    |          |
|             |      |            |         | Only applicable when DRC_KNEE2_OP_ENA = 1.         |          |
|             | 7:3  | DRC_KNEE_O | 0_0000  | Output signal at the Compressor 'Knee1'.           |          |
|             |      | P[4:0]     |         | 00000 = 0dB                                        |          |
|             |      |            |         | 00001 = -0.75dB                                    |          |
|             |      |            |         | 00010 = -1.5dB                                     |          |
|             |      |            |         | (-0.75dB steps)                                    |          |
|             |      |            |         | 11110 = -22.5dB                                    |          |
|             |      |            |         | 11111 = Reserved                                   |          |
|             | 2:0  | DRC_HI_COM | 011     | Compressor slope (upper region)                    |          |
|             |      | P[2:0]     |         | 000 = 1 (no compression)                           |          |
|             |      |            |         | 001 = 1/2                                          |          |
|             |      |            |         | 010 = 1/4                                          |          |
|             |      |            |         | 011 = 1/8                                          |          |
|             |      |            |         | 100 = 1/16                                         |          |
|             |      |            |         | 101 = 0                                            |          |
|             |      |            |         | 110 = Reserved                                     |          |
|             |      |            |         | 111 = Reserved                                     |          |

Register 21h DRC Control 5

| REGISTER    | BIT | LABEL      | DEFAULT | DESCRIPTION                                      | REFER TO |
|-------------|-----|------------|---------|--------------------------------------------------|----------|
| ADDRESS     |     |            |         |                                                  |          |
| R34 (22h)   | 3:2 | DRC_QR_THR | 00      | DRC Quick-release threshold (crest factor in dB) |          |
| DRC Control |     | [1:0]      |         | 00 = 12dB                                        |          |
| 6           |     |            |         | 01 = 18dB                                        |          |
|             |     |            |         | 10 = 24dB                                        |          |
|             |     |            |         | 11 = 30dB                                        |          |
|             | 1:0 | DRC_QR_DCY | 00      | DRC Quick-release decay rate (seconds/6dB)       |          |
|             |     | [1:0]      |         | 00 = 0.725ms                                     |          |
|             |     |            |         | 01 = 1.45ms                                      |          |
|             |     |            |         | 10 = 5.8ms                                       |          |
|             |     |            |         | 11 = reserved                                    |          |

Register 22h DRC Control 6

| REGISTER    | BIT | LABEL      | DEFAULT | DESCRIPTION                     | REFER TO |
|-------------|-----|------------|---------|---------------------------------|----------|
| ADDRESS     |     |            |         |                                 |          |
| R35 (23h)   | 9:8 | DRC_NG_EXP | 00      | Noise Gate slope                |          |
| DRC Control |     | [1:0]      |         | 00 = 1 (no expansion)           |          |
| 7           |     |            |         | 01 = 2                          |          |
|             |     |            |         | 10 = 4                          |          |
|             |     |            |         | 11 = 8                          |          |
|             | 7:5 | DRC_LO_COM | 000     | Compressor slope (lower region) |          |
|             |     | P[2:0]     |         | 000 = 1 (no compression)        |          |
|             |     |            |         | 001 = 1/2                       |          |
|             |     |            |         | 010 = 1/4                       |          |
|             |     |            |         | 011 = 1/8                       |          |
|             |     |            |         | 100 = 0                         |          |
|             |     |            |         | 101 = Reserved                  |          |
|             |     |            |         | 11X = Reserved                  |          |
|             | 4:0 | DRC_INIT   | 00000   | Initial value at DRC startup    |          |
|             |     |            |         | 00000 = 0dB                     |          |
|             |     |            |         | 00001 = -3.75dB                 |          |
|             |     |            |         | (-3.75dB steps)                 |          |
|             |     |            |         | 11111 = -116.25dB               |          |

Register 23h DRC Control 7

| REGISTER   | BIT  | LABEL    | DEFAULT   | DESCRIPTION                                             | REFER TO |
|------------|------|----------|-----------|---------------------------------------------------------|----------|
| ADDRESS    |      |          |           |                                                         |          |
| R36 (24h)  | 15:0 | DRC_GAIN | 0000_0000 | DRC Gain value.                                         |          |
| DRC Status |      | [15:0]   |           | This is the Brogain, expressed as a voltage manipher.   |          |
|            |      |          | 0         | Fixed point coding, MSB = 64.                           |          |
|            |      |          |           | The first 7 bits are the integer portion; the remaining |          |
|            |      |          |           | bits are the fractional part.                           |          |

Register 24h DRC Status

| REGISTER  | BIT | LABEL     | DEFAULT | DESCRIPTION                                                                                   | REFER TO |
|-----------|-----|-----------|---------|-----------------------------------------------------------------------------------------------|----------|
| ADDRESS   |     |           |         |                                                                                               |          |
| R37 (25h) | 6:3 | BEEP_GAIN | 0000    | Digital Beep Volume Control                                                                   |          |
| Веер      |     | [3:0]     |         | 0000 = mute                                                                                   |          |
| Control 1 |     |           |         | 0001 = -83dB                                                                                  |          |
|           |     |           |         | 0010 = -77dB                                                                                  |          |
|           |     |           |         | (6dB steps)                                                                                   |          |
|           |     |           |         | 1111 = +1dB                                                                                   |          |
|           | 2:1 | BEEP_RATE | 01      | Beep Waveform Control                                                                         |          |
|           |     | [1:0]     |         | 00 = Reserved                                                                                 |          |
|           |     |           |         | 01 = 1kHz                                                                                     |          |
|           |     |           |         | 10 = 2kHz                                                                                     |          |
|           |     |           |         | 11 = 4kHz                                                                                     |          |
|           | 0   | BEEP_ENA  | 0       | Digital Beep Enable                                                                           |          |
|           |     |           |         | 0 = Disabled                                                                                  |          |
|           |     |           |         | 1 = Enabled                                                                                   |          |
|           |     |           |         | Note that the DAC and associated signal path needs to be enabled when using the digital beep. |          |

Register 25h Beep Control 1



| REGISTER     | BIT | LABEL     | DEFAULT | DESCRIPTION                                                                                                                   | REFER TO |
|--------------|-----|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------|----------|
| ADDRESS      |     |           |         |                                                                                                                               |          |
| R38 (26h)    | 7   | VB_ENA    | 0       | Video buffer enable                                                                                                           |          |
| Video Buffer |     |           |         | 0 = Disabled                                                                                                                  |          |
|              |     |           |         | 1 = Enabled                                                                                                                   |          |
|              | 6   | VB_QBOOST | 0       | Video buffer filter Q-Boost control                                                                                           |          |
|              |     |           |         | 0 = Disabled                                                                                                                  |          |
|              |     |           |         | 1 = Enabled                                                                                                                   |          |
|              | 5   | VB_GAIN   | 0       | Video buffer gain                                                                                                             |          |
|              |     |           |         | 0 = 0dB (=6dB unloaded)                                                                                                       |          |
|              |     |           |         | 1 = 6dB (=12dB unloaded)                                                                                                      |          |
|              | 4:2 | VB_DISOFF | 111     | Video buffer DC offset control                                                                                                |          |
|              |     | [2:0]     |         | 000 = Reserved                                                                                                                |          |
|              |     |           |         | 001 = 40mV offset                                                                                                             |          |
|              |     |           |         | 010 = Reserved                                                                                                                |          |
|              |     |           |         | 011 = 20mV offset                                                                                                             |          |
|              |     |           |         | 100 = Reserved                                                                                                                |          |
|              |     |           |         | 101 = Reserved                                                                                                                |          |
|              |     |           |         | 110 = Reserved                                                                                                                |          |
|              |     |           |         | 111 = 0mV offset                                                                                                              |          |
|              |     |           |         | Note – the specified offset applies to the 0dB gain setting (VB_GAIN=0). When 6dB gain is selected, the DC offset is doubled. |          |
|              | 1   | VB_PD     | 0       | Video buffer pull-down                                                                                                        |          |
|              |     | _         |         | 0 = pull-down disabled                                                                                                        |          |
|              |     |           |         | 1 = pull-down enabled                                                                                                         |          |
|              | 0   | VB_CLAMP  | 0       | Enable the clamp between the video input and ground                                                                           |          |
|              |     |           |         | 0 = no clamp                                                                                                                  |          |
|              |     |           |         | 1 = Video buffer input is clamped to ground                                                                                   |          |

Register 26h Video Buffer

| REGISTER<br>ADDRESS | BIT | LABEL         | DEFAULT | DESCRIPTION                                | REFER TO |
|---------------------|-----|---------------|---------|--------------------------------------------|----------|
| R39 (27h)           | 8   | AUX2_AUDIO    | 0       | AUX2 pin configuration                     |          |
| Input ctrl          |     |               |         | 0 = Non-Audio signal                       |          |
|                     |     |               |         | 1 = AC-coupled Audio signal                |          |
|                     | 7   | AUX1_AUDIO    | 0       | AUX1 pin configuration                     |          |
|                     |     |               |         | 0 = Non-Audio signal                       |          |
|                     |     |               |         | 1 = AC-coupled Audio signal                |          |
|                     | 6   | MICB_LVL      | 0       | Microphone Bias Voltage control            |          |
|                     |     |               |         | 0 = 0.9 x LDOVOUT                          |          |
|                     |     |               |         | 1 = 0.65 x LDOVOUT                         |          |
|                     | 5   | 5 MICRN_TO_N_ | . 1     | Right Input PGA Inverting Input Select     |          |
|                     |     | PGAR          |         | 0 = Connected to VMID                      |          |
|                     |     |               |         | 1 = Connected to IN2R                      |          |
|                     | 4   | 4 MICLN_TO_N_ | 1       | Left Input PGA Inverting Input Select      |          |
|                     |     | PGAL          |         | 0 = Connected to VMID                      |          |
|                     |     |               |         | 1 = Connected to IN2L                      |          |
|                     | 3:2 | P_PGAR_SEL    | 01      | Right Input PGA Non-Inverting Input Select |          |
|                     |     | [1:0]         |         | 00 = Connected to IN2R                     |          |
|                     |     |               |         | 01 = Connected to IN1R                     |          |
|                     |     |               |         | 10 = Connected to AUX2                     |          |
|                     |     |               |         | 11 = Reserved                              |          |



WM8946 Production Data

| REGISTER | BIT | LABEL      | DEFAULT | DESCRIPTION                               | REFER TO |
|----------|-----|------------|---------|-------------------------------------------|----------|
| ADDRESS  |     |            |         |                                           |          |
|          | 1:0 | P_PGAL_SEL | 01      | Left Input PGA Non-Inverting Input Select |          |
|          |     | [1:0]      |         | 00 = Connected to IN2L                    |          |
|          |     |            |         | 01 = Connected to IN1L                    |          |
|          |     |            |         | 10 = Connected to AUX1                    |          |
|          |     |            |         | 11 = Reserved                             |          |

Register 27h Input ctrl

| REGISTER             | BIT | LABEL        | DEFAULT | DESCRIPTION                                                                                           | REFER TO |
|----------------------|-----|--------------|---------|-------------------------------------------------------------------------------------------------------|----------|
| ADDRESS              |     |              |         |                                                                                                       |          |
| R40 (28h)            | 8   | PGA_VU       | 0       | Input PGA Volume Update                                                                               |          |
| Left INP<br>PGA gain |     |              |         | Writing a 1 to this bit will cause the Left and Right Input PGA volumes to be updated simultaneously. |          |
| ctrl                 | 7   | PGAL_ZC      | 0       | Left Input PGA Zero Cross Detector                                                                    |          |
|                      |     |              |         | 0 = Change gain immediately                                                                           |          |
|                      |     |              |         | 1 = Change gain on zero cross only                                                                    |          |
|                      | 6   | PGAL_MUTE    | 1       | Left Input PGA Mute                                                                                   |          |
|                      |     |              |         | 0 = Disable Mute                                                                                      |          |
|                      |     |              |         | 1 = Enable Mute                                                                                       |          |
|                      | 5:0 | PGAL_VOL[5:0 | 01_0000 | Left Input PGA Volume                                                                                 |          |
|                      |     | ]            |         | 00_0000 = -12dB                                                                                       |          |
|                      |     |              |         | 00_0001 = -11.25dB                                                                                    |          |
|                      |     |              |         |                                                                                                       |          |
|                      |     |              |         | 01_0000 = 0dB                                                                                         |          |
|                      |     |              |         |                                                                                                       |          |
|                      |     |              |         | 11_1111 = +35.25                                                                                      |          |

Register 28h Left INP PGA gain ctrl

| REGISTER              | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                           | REFER TO |
|-----------------------|-----|-------------|---------|-------------------------------------------------------------------------------------------------------|----------|
| ADDRESS               |     |             |         |                                                                                                       |          |
| R41 (29h)             | 8   | PGA_VU      | 0       | Input PGA Volume Update                                                                               |          |
| Right INP<br>PGA gain |     |             |         | Writing a 1 to this bit will cause the Left and Right Input PGA volumes to be updated simultaneously. |          |
| ctrl                  | 7   | PGAR_ZC     | 0       | Right Input PGA Zero Cross Detector                                                                   |          |
|                       |     |             |         | 0 = Change gain immediately                                                                           |          |
|                       |     |             |         | 1 = Change gain on zero cross only                                                                    |          |
|                       | 6   | PGAR_MUTE   | 1       | Right Input PGA Mute                                                                                  |          |
|                       |     |             |         | 0 = Disable Mute                                                                                      |          |
|                       |     |             |         | 1 = Enable Mute                                                                                       |          |
|                       | 5:0 | PGAR_VOL[5: | 01_0000 | Right Input PGA Volume                                                                                |          |
|                       |     | 0]          |         | 00_0000 = -12dB                                                                                       |          |
|                       |     |             |         | 00_0001 = -11.25dB                                                                                    |          |
|                       |     |             |         |                                                                                                       |          |
|                       |     |             |         | 01_0000 = 0dB                                                                                         |          |
|                       |     |             |         |                                                                                                       |          |
|                       |     |             |         | 11_1111 = +35.25                                                                                      |          |

Register 29h Right INP PGA gain ctrl



| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                                                          | REFER TO |
|---------------------|-----|-------------|---------|------------------------------------------------------------------------------------------------------|----------|
| R42 (2Ah)           | 15  | THERR ACT   | 1       | Thermal Shutdown enable                                                                              |          |
| Output ctrl         |     | _           |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     |     |             |         | When THERR_ACT = 1, then an overtemperature condition will cause the speaker outputs to be disabled. |          |
|                     | 13  | SPKR_VMID_  | 0       | Buffered VMID to SPKOUTR Enable                                                                      |          |
|                     |     | OP_ENA      |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 12  | SPKL_VMID_O | 0       | Buffered VMID to SPKOUTL Enable                                                                      |          |
|                     |     | P_ENA       |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 11  | LINER_VMID_ | 0       | Buffered VMID to LINEOUTR Enable                                                                     |          |
|                     |     | OP_ENA      |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 10  | LINEL_VMID_ | 0       | Buffered VMID to LINEOUTL Enable                                                                     |          |
|                     |     | OP_ENA      |         | 0 = Disabled                                                                                         |          |
|                     |     |             |         | 1 = Enabled                                                                                          |          |
|                     | 9   | LINER_MUTE  | 1       | LINEOUTR Output Mute                                                                                 |          |
|                     |     |             | -       | 0 = Disable Mute                                                                                     |          |
|                     |     |             |         | 1 = Enable Mute                                                                                      |          |
|                     | 8   | LINEL_MUTE  | 1       | LINEOUTL Output Mute                                                                                 |          |
|                     |     | _           |         | 0 = Disable Mute                                                                                     |          |
|                     |     |             |         | 1 = Enable Mute                                                                                      |          |
|                     | 7   | SPKR_DISCH  | 0       | Discharges SPKOUTR output via approx 4k resistor                                                     |          |
|                     |     | _           |         | 0 = Not active                                                                                       |          |
|                     |     |             |         | 1 = Actively discharging SPKOUTR                                                                     |          |
|                     | 6   | SPKL_DISCH  | 0       | Discharges SPKOUTL output via approx 4k resistor                                                     |          |
|                     |     | _           |         | 0 = Not active                                                                                       |          |
|                     |     |             |         | 1 = Actively discharging SPKOUTL                                                                     |          |
|                     | 5   | LINER_DISCH | 0       | Discharges LINEOUTR output via approx 4k resistor                                                    |          |
|                     |     |             |         | 0 = Not active                                                                                       |          |
|                     |     |             |         | 1 = Actively discharging LINEOUTR                                                                    |          |
|                     | 4   | LINEL_DISCH | 0       | Discharges LINEOUTL output via approx 4k resistor                                                    |          |
|                     |     |             |         | 0 = Not active                                                                                       |          |
|                     |     |             |         | 1 = Actively discharging LINEOUTL                                                                    |          |
|                     | 1   | SPK_VROI    | 0       | Buffered VREF to SPKOUTL / SPKOUTR resistance (Disabled outputs)                                     |          |
|                     |     |             |         | 0 = approx 20k                                                                                       |          |
|                     |     |             |         | 1 = approx 1k                                                                                        |          |
|                     | 0   | LINE_VROI   | 0       | Buffered VREF to LINEOUTL / LINEOUTR resistance (Disabled outputs)                                   |          |
|                     |     |             |         | 0 = approx 20k                                                                                       |          |
|                     |     |             |         | 1 = approx 1k                                                                                        |          |

Register 2Ah Output ctrl

| REGISTER  | BIT | LABEL               | DEFAULT | DESCRIPTION                                                     | REFER TO |
|-----------|-----|---------------------|---------|-----------------------------------------------------------------|----------|
| ADDRESS   |     |                     |         |                                                                 |          |
| R43 (2Bh) | 8   | AUX1_TO_SP          | 0       | AUX1 Audio Input to Left Speaker Output select                  |          |
| SPK mixer |     | KL                  |         | 0 = Disabled                                                    |          |
| control1  |     |                     |         | 1 = Enabled                                                     |          |
|           | 7   | PGAL_TO_SP          | 0       | Left Speaker PGA Mixer to Left Speaker Output select            |          |
|           |     | KL                  |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 6   | BYPL_TO_PG<br>AL    | 0       | Left Input PGA (ADC bypass) to Left Speaker PGA<br>Mixer select |          |
|           |     |                     |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 5   | MDACL_TO_P          | 0       | Inverted Left DAC to Left Speaker PGA Mixer select              |          |
|           |     | GAL                 |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 4   | 4 MDACR_TO_P<br>GAL | 0       | Inverted Right DAC to Left Speaker PGA Mixer select             |          |
|           |     |                     |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 3   | DACL_TO_PG          | 0       | Left DAC to Left Speaker PGA Mixer select                       |          |
|           |     | AL                  |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 2   | DACR_TO_PG          | 0       | Right DAC to Left Speaker PGA Mixer select                      |          |
|           |     | AL                  |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 1   | AUX2_TO_PG          | 0       | AUX2 Audio Input to Left Speaker PGA Mixer select               |          |
|           |     | AL                  |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |
|           | 0   | AUX1_TO_PG          | 0       | AUX1 Audio Input to Left Speaker PGA Mixer select               |          |
|           |     | AL                  |         | 0 = Disabled                                                    |          |
|           |     |                     |         | 1 = Enabled                                                     |          |

Register 2Bh SPK mixer control1

| REGISTER  | BIT | LABEL            | DEFAULT | DESCRIPTION                                          | REFER TO |
|-----------|-----|------------------|---------|------------------------------------------------------|----------|
| ADDRESS   |     |                  |         |                                                      |          |
| R44 (2Ch) | 8   | AUX1_TO_SP       | 0       | AUX1 Audio Input to Right Speaker Output select      |          |
| SPK mixer |     | KR               |         | 0 = Disabled                                         |          |
| control2  |     |                  |         | 1 = Enabled                                          |          |
|           | 7   | PGAR_TO_SP       | 0       | Right Speaker PGA Mixer to Right Speaker Output      |          |
|           |     | KR               |         | select                                               |          |
|           |     |                  |         | 0 = Disabled                                         |          |
|           |     |                  |         | 1 = Enabled                                          |          |
|           | 6   | BYPR_TO_PG<br>AR | 0       | Right Input PGA (ADC bypass) to Right Speaker PGA    |          |
|           |     |                  |         | Mixer select                                         |          |
|           |     |                  |         | 0 = Disabled                                         |          |
|           |     |                  |         | 1 = Enabled                                          |          |
|           | 5   | MDACL_TO_P       | 0       | Inverted Left DAC to Right Speaker PGA Mixer select  |          |
|           |     | GAR              |         | 0 = Disabled                                         |          |
|           |     |                  |         | 1 = Enabled                                          |          |
|           | 4   | MDACR_TO_P       | 0       | Inverted Right DAC to Right Speaker PGA Mixer select |          |
|           |     | GAR              |         | 0 = Disabled                                         |          |
|           |     |                  |         | 1 = Enabled                                          |          |
|           | 3   | DACL_TO_PG       | 0       | Left DAC to Right Speaker PGA Mixer select           |          |
|           |     | ĀR               |         | 0 = Disabled                                         |          |



| REGISTER | BIT | LABEL      | DEFAULT | DESCRIPTION                                        | REFER TO |
|----------|-----|------------|---------|----------------------------------------------------|----------|
| ADDRESS  |     |            |         |                                                    |          |
|          |     |            |         | 1 = Enabled                                        |          |
|          | 2   | DACR_TO_PG | 0       | Right DAC to Right Speaker PGA Mixer select        |          |
|          |     | AR         |         | 0 = Disabled                                       |          |
|          |     |            |         | 1 = Enabled                                        |          |
|          | 1   | AUX2_TO_PG | 0       | AUX2 Audio Input to Right Speaker PGA Mixer select |          |
|          |     | AR         |         | 0 = Disabled                                       |          |
|          |     |            |         | 1 = Enabled                                        |          |
|          | 0   | AUX1_TO_PG | 0       | AUX1 Audio Input to Right Speaker PGA Mixer select |          |
|          |     | AR         |         | 0 = Disabled                                       |          |
|          |     |            |         | 1 = Enabled                                        |          |

Register 2Ch SPK mixer control2

| REGISTER  | BIT | LABEL      | DEFAULT | DESCRIPTION                                         | REFER TO |
|-----------|-----|------------|---------|-----------------------------------------------------|----------|
| ADDRESS   |     |            |         |                                                     |          |
| R45 (2Dh) | 8   | AUX1_TO_SP | 0       | AUX1 Audio Input to Left Speaker Output attenuation |          |
| SPK mixer |     | KL_ATTEN   |         | 0 = 0dB                                             |          |
| control3  |     |            |         | 1 = -6dB attenuation                                |          |
|           | 7   | PGAL_TO_SP | 0       | Left Speaker PGA Mixer to Left Speaker Output       |          |
|           |     | KL_ATTEN   |         | attenuation                                         |          |
|           |     |            |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |
|           | 6   | BYPL_TO_PG | 0       | Left Input PGA (ADC bypass) to Left Speaker PGA     |          |
|           |     | AL_ATTEN   |         | Mixer attenuation                                   |          |
|           |     |            |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |
|           | 3   | DACL_TO_PG | 0       | Left DAC to Left Speaker PGA Mixer attenuation      |          |
|           |     | AL_ATTEN   |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |
|           | 2   | DACR_TO_PG | 0       | Right DAC to Left Speaker PGA Mixer attenuation     |          |
|           |     | AL_ATTEN   |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |
|           | 1   | AUX2_TO_PG | 0       | AUX2 Audio Input to Left Speaker PGA Mixer          |          |
|           |     | AL_ATTEN   |         | attenuation                                         |          |
|           |     |            |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |
|           | 0   | AUX1_TO_PG | 0       | AUX1 Audio Input to Left Speaker PGA Mixer          |          |
|           |     | AL_ATTEN   |         | attenuation                                         |          |
|           |     |            |         | 0 = 0dB                                             |          |
|           |     |            |         | 1 = -6dB attenuation                                |          |

Register 2Dh SPK mixer control3

| REGISTER<br>ADDRESS                | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                                                      | REFER TO |
|------------------------------------|-----|------------------------|---------|--------------------------------------------------------------------------------------------------|----------|
| R46 (2Eh)<br>SPK mixer<br>control4 | 8   | AUX1_TO_SP<br>KR_ATTEN | 0       | AUX1 Audio Input to Right Speaker Output attenuation 0 = 0dB 1 = -6dB attenuation                |          |
|                                    | 7   | PGAR_TO_SP<br>KR_ATTEN | 0       | Right Speaker PGA Mixer to Right Speaker Output attenuation 0 = 0dB 1 = -6dB attenuation         |          |
|                                    | 6   | BYPR_TO_PG<br>AR_ATTEN | 0       | Right Input PGA (ADC bypass) to Right Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation |          |
|                                    | 3   | DACL_TO_PG<br>AR_ATTEN | 0       | Left DAC to Right Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                     |          |
|                                    | 2   | DACR_TO_PG<br>AR_ATTEN | 0       | Right DAC to Right Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation                    |          |
|                                    | 1   | AUX2_TO_PG<br>AR_ATTEN | 0       | AUX2 Audio Input to Right Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation             |          |
|                                    | 0   | AUX1_TO_PG<br>AR_ATTEN | 0       | AUX1 Audio Input to Right Speaker PGA Mixer attenuation 0 = 0dB 1 = -6dB attenuation             |          |

Register 2Eh SPK mixer control4

| REGISTER<br>ADDRESS     | BIT | LABEL        | DEFAULT | DESCRIPTION                                                                                             | REFER TO |
|-------------------------|-----|--------------|---------|---------------------------------------------------------------------------------------------------------|----------|
| R47 (2Fh)               | 8   | SPK_VU       | 0       | Speaker PGA Volume Update                                                                               |          |
| Left SPK<br>volume ctrl |     |              |         | Writing a 1 to this bit will cause the Left and Right Speaker PGA volumes to be updated simultaneously. |          |
|                         | 7   | SPKL_ZC      | 0       | Left Speaker PGA Zero Cross Detector                                                                    |          |
|                         |     |              |         | 0 = Change gain immediately                                                                             |          |
|                         |     |              |         | 1 = Change gain on zero cross only                                                                      |          |
|                         | 6   | SPKL_PGA_M   | 1       | Left Speaker PGA Mute                                                                                   |          |
|                         |     | UTE          |         | 0 = Disable Mute                                                                                        |          |
|                         |     |              |         | 1 = Enable Mute                                                                                         |          |
|                         | 5:0 | SPKL_VOL[5:0 | 11_1001 | Left Speaker PGA Volume                                                                                 |          |
|                         |     | ]            |         | 00_0000 = -57dB gain                                                                                    |          |
|                         |     |              |         | 00_0001 = -56dB                                                                                         |          |
|                         |     |              |         |                                                                                                         |          |
|                         |     |              |         | 11_1001 = 0dB                                                                                           |          |
|                         |     |              |         |                                                                                                         |          |
|                         |     |              |         | 11_1111 = +6dB                                                                                          |          |

Register 2Fh Left SPK volume ctrl



| REGISTER<br>ADDRESS   | BIT | LABEL        | DEFAULT | DESCRIPTION                                                                                             | REFER TO |
|-----------------------|-----|--------------|---------|---------------------------------------------------------------------------------------------------------|----------|
| R48 (30h)             | 8   | SPK_VU       | 0       | Speaker PGA Volume Update                                                                               |          |
| Right SPK volume ctrl |     |              |         | Writing a 1 to this bit will cause the Left and Right Speaker PGA volumes to be updated simultaneously. |          |
|                       | 7   | SPKR_ZC      | 0       | Right Speaker PGA Zero Cross Detector                                                                   |          |
|                       |     |              |         | 0 = Change gain immediately                                                                             |          |
|                       |     |              |         | 1 = Change gain on zero cross only                                                                      |          |
|                       | 6   | SPKR_PGA_M   | 1       | Right Speaker PGA Mute                                                                                  |          |
|                       |     | UTE          |         | 0 = Disable Mute                                                                                        |          |
|                       |     |              |         | 1 = Enable Mute                                                                                         |          |
|                       | 5:0 | SPKR_VOL[5:0 | 11_1001 | Right Speaker PGA Volume                                                                                |          |
|                       |     | ]            |         | 00_0000 = -57dB gain                                                                                    |          |
|                       |     |              |         | 00_0001 = -56dB                                                                                         |          |
|                       |     |              |         |                                                                                                         |          |
|                       |     |              |         | 11_1001 = 0dB                                                                                           |          |
|                       |     |              |         |                                                                                                         |          |
|                       |     |              |         | 11_1111 = +6dB                                                                                          |          |

Register 30h Right SPK volume ctrl

| REGISTER     | BIT | LABEL      | DEFAULT | DESCRIPTION                                      | REFER TO |
|--------------|-----|------------|---------|--------------------------------------------------|----------|
| ADDRESS      |     |            |         |                                                  |          |
| R49 (31h)    | 6   | BYPL_TO_OU | 0       | Left Input PGA (ADC bypass) to Left Output Mixer |          |
| Line L mixer |     | TL         |         | select                                           |          |
| control 1    |     |            |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 5   | MDACL_TO_O | 0       | Inverted Left DAC to Left Output Mixer select    |          |
|              |     | UTL        |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 4   | MDACR_TO_O | 0       | Inverted Right DAC to Left Output Mixer select   |          |
|              |     | UTL        |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 3   | DACL_TO_OU | 0       | Left DAC to Left Output Mixer select             |          |
|              |     | TL         |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 2   | DACR_TO_OU | 0       | Right DAC to Left Output Mixer select            |          |
|              |     | TL T       |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 1   | AUX2_TO_OU | 0       | AUX2 Audio Input to Left Output Mixer select     |          |
|              |     | TL         |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |
|              | 0   | AUX1_TO_OU | 0       | AUX1 Audio Input to Left Output Mixer select     |          |
|              |     | TL         |         | 0 = Disabled                                     |          |
|              |     |            |         | 1 = Enabled                                      |          |

Register 31h Line L mixer control 1

| REGISTER<br>ADDRESS       | BIT | LABEL            | DEFAULT | DESCRIPTION                                               | REFER TO |
|---------------------------|-----|------------------|---------|-----------------------------------------------------------|----------|
| R50 (32h)<br>Line R mixer | 6   | BYPR_TO_OU<br>TR | 0       | Right Input PGA (ADC bypass) to Right Output Mixer select |          |
| control 1                 |     |                  |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 5   | MDACL_TO_O       | 0       | Inverted Left DAC to Right Output Mixer select            |          |
|                           |     | UTR              |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 4   | MDACR_TO_O       | 0       | Inverted Right DAC to Right Output Mixer select           |          |
|                           |     | UTR              |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 3   | DACL_TO_OU       | 0       | Left DAC to Right Output Mixer select                     |          |
|                           |     | TR               |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 2   | DACR_TO_OU       | 0       | Right DAC to Right Output Mixer select                    |          |
|                           |     | TR               |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 1   | AUX2_TO_OU       | 0       | AUX2 Audio Input to Right Output Mixer select             |          |
|                           |     | TR               |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |
|                           | 0   | AUX1_TO_OU       | 0       | AUX1 Audio Input to Right Output Mixer select             |          |
|                           |     | TR               |         | 0 = Disabled                                              |          |
|                           |     |                  |         | 1 = Enabled                                               |          |

Register 32h Line R mixer control 1

| REGISTER     | BIT | LABEL      | DEFAULT | DESCRIPTION                                       | REFER TO |
|--------------|-----|------------|---------|---------------------------------------------------|----------|
| ADDRESS      |     |            |         |                                                   |          |
| R51 (33h)    | 6   | BYPL_TO_OU | 0       | Left Input PGA (ADC bypass) to Left Output Mixer  |          |
| Line L mixer |     | TL_ATTEN   |         | attenuation                                       |          |
| control 2    |     |            |         | 0 = 0dB                                           |          |
|              |     |            |         | 1 = -6dB attenuation                              |          |
|              | 3   | DACL_TO_OU | 0       | Left DAC to Left Output Mixer attenuation         |          |
|              |     | TL_ATTEN   |         | 0 = 0dB                                           |          |
|              |     |            |         | 1 = -6dB attenuation                              |          |
|              | 2   | DACR_TO_OU | 0       | Right DAC to Left Output Mixer attenuation        |          |
|              |     | TL_ATTEN   |         | 0 = 0dB                                           |          |
|              |     |            |         | 1 = -6dB attenuation                              |          |
|              | 1   | AUX2_TO_OU | 0       | AUX2 Audio Input to Left Output Mixer attenuation |          |
|              |     | TL_ATTEN   |         | 0 = 0dB                                           |          |
|              |     |            |         | 1 = -6dB attenuation                              |          |
|              | 0   | AUX1_TO_OU | 0       | AUX1 Audio Input to Left Output Mixer attenuation |          |
|              |     | TL_ATTEN   |         | 0 = 0dB                                           |          |
|              |     |            |         | 1 = -6dB attenuation                              |          |

Register 33h Line L mixer control 2



| REGISTER                  | BIT | LABEL                  | DEFAULT | DESCRIPTION                                                    | REFER TO |
|---------------------------|-----|------------------------|---------|----------------------------------------------------------------|----------|
| ADDRESS                   |     |                        |         |                                                                |          |
| R52 (34h)<br>Line R mixer | 6   | BYPR_TO_OU<br>TR_ATTEN | 0       | Right Input PGA (ADC bypass) to Right Output Mixer attenuation |          |
| control 2                 |     |                        |         | 0 = 0dB                                                        |          |
|                           |     |                        |         | 1 = -6dB attenuation                                           |          |
|                           | 3   | DACL_TO_OU             | 0       | Left DAC to Right Output Mixer attenuation                     |          |
|                           |     | TR_ATTEN               |         | 0 = 0dB                                                        |          |
|                           |     |                        |         | 1 = -6dB attenuation                                           |          |
|                           | 2   | DACR_TO_OU             | 0       | Right DAC to Right Output Mixer attenuation                    |          |
|                           |     | TR_ATTEN               |         | 0 = 0dB                                                        |          |
|                           |     |                        |         | 1 = -6dB attenuation                                           |          |
|                           | 1   | AUX2_TO_OU             | 0       | AUX2 Audio Input to Right Output Mixer attenuation             |          |
|                           |     | TR_ATTEN               |         | 0 = 0dB                                                        |          |
|                           |     |                        |         | 1 = -6dB attenuation                                           |          |
|                           | 0   | AUX1_TO_OU             | 0       | AUX1 Audio Input to Right Output Mixer attenuation             |          |
|                           |     | TR_ATTEN               |         | 0 = 0dB                                                        |          |
|                           |     |                        |         | 1 = -6dB attenuation                                           |          |

Register 34h Line R mixer control 2

| REGISTER  | BIT | LABEL       | DEFAULT | DESCRIPTION                                             | REFER TO |
|-----------|-----|-------------|---------|---------------------------------------------------------|----------|
| ADDRESS   |     |             |         |                                                         |          |
| R53 (35h) | 15  | LDO_ENA     | 0       | LDO Enable                                              |          |
| LDO       |     |             |         | 0 = Disabled                                            |          |
|           |     |             |         | 1 = Enabled                                             |          |
|           | 14  | LDO_REF_SE  | 0       | LDO Voltage reference select                            |          |
|           |     | L_FAST      |         | 0 = VMID (normal)                                       |          |
|           |     |             |         | 1 = VMID (fast start)                                   |          |
|           |     |             |         | This field is only effective when LDO_REF_SEL = 0       |          |
|           | 13  | LDO_REF_SE  | 0       | LDO Voltage reference select                            |          |
|           |     | L           |         | 0 = VMID                                                |          |
|           |     |             |         | 1 = Bandgap                                             |          |
|           | 12  | LDO_OPFLT   | 0       | LDO Output float                                        |          |
|           |     |             |         | 0 = Disabled (Output discharged when disabled)          |          |
|           |     |             |         | 1 = Enabled (Output floats when disabled)               |          |
|           | 5   | LDO_BIAS_SR | 0       | LDO Bias Source select                                  |          |
|           |     | С           |         | 0 = Master Bias                                         |          |
|           |     |             |         | 1 = Start-Up Bias                                       |          |
|           | 4:0 | LDO_VSEL    | 0_0111  | LDO Voltage select                                      |          |
|           |     | [4:0]       |         | (Sets the LDO output as a ratio of the selected voltage |          |
|           |     |             |         | reference. The voltage reference is set by              |          |
|           |     |             |         | LDO_REF_SEL.)                                           |          |
|           |     |             |         | 00111 = Vref x 1.97 (default)                           |          |

Register 35h LDO

| REGISTER<br>ADDRESS  | BIT | LABEL        | DEFAULT | DESCRIPTION                                                                                                                                                               | REFER TO |
|----------------------|-----|--------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| R54 (36h)<br>Bandgap | 15  | BG_ENA       | 0       | Bandgap Reference Control 0 = Disabled 1 = Enabled                                                                                                                        |          |
|                      | 4:0 | BG_VSEL[4:0] | 0_1010  | Bandgap Voltage select (Sets the Bandgap voltage) 00000 = 1.200V 26.7mV steps 01010 = 1.467V (default) 01111 = 1.600V 10000 to 11111 = reserved (See Table 40 for values) |          |

Register 36h Bandgap

| REGISTER  | BIT | LABEL     | DEFAULT | DESCRIPTION                   | REFER TO |
|-----------|-----|-----------|---------|-------------------------------|----------|
| ADDRESS   |     |           |         |                               |          |
| R64 (40h) | 3:0 | SE_CONFIG | 0000    | DSP Configuration Mode select |          |
| SE Config |     | [3:0]     |         | 0000 = Record mode            |          |
| Selection |     |           |         | 0001 = Playback mode          |          |
|           |     |           |         | 0010 = Reserved               |          |
|           |     |           |         | 0011 = Reserved               |          |

Register 40h SE Config Selection

| REGISTER  | BIT | LABEL              | DEFAULT | DESCRIPTION                                          | REFER TO |
|-----------|-----|--------------------|---------|------------------------------------------------------|----------|
| ADDRESS   |     |                    |         |                                                      |          |
| R65 (41h) | 5   | SE1_LHPF_R_        | 0       | SE1_LHPF_R_SIGN                                      |          |
| SE1_LHPF_ |     | SIGN               |         | 0 : sum internal result (LPF)                        |          |
| CONFIG    |     |                    |         | 1 : sub internal result (HPF)                        |          |
|           | 4   | SE1_LHPF_L_        | 0       | SE1_LHPF_L_SIGN                                      |          |
|           |     | SIGN               |         | 0 : sum internal result (LPF)                        |          |
|           |     |                    |         | 1 : sub internal result (HPF)                        |          |
|           | 1   | SE1_LHPF_R_<br>ENA | 0       | SE1 Right channel low-pass / high-pass filter enable |          |
|           |     |                    |         | 0 = Disabled                                         |          |
|           |     |                    |         | 1 = Enabled                                          |          |
|           | 0   | SE1_LHPF_L_        | 0       | SE1 Left channel low-pass / high-pass filter enable  |          |
|           |     | ENA                |         | 0 = Disabled                                         |          |
|           |     |                    |         | 1 = Enabled                                          |          |

Register 41h SE1\_LHPF\_CONFIG

| REGISTER<br>ADDRESS         | BIT  | LABEL                | DEFAULT                | DESCRIPTION                       | REFER TO |
|-----------------------------|------|----------------------|------------------------|-----------------------------------|----------|
| R66 (42h)<br>SE1_LHPF_<br>L | 15:0 | SE1_LHPF_L<br>[15:0] | 0000_0000<br>_0000_000 | SE1_LHPF left channel coefficient |          |

Register 42h SE1\_LHPF\_L

| REGISTER<br>ADDRESS         | BIT  | LABEL                | DEFAULT                     | DESCRIPTION                        | REFER TO |
|-----------------------------|------|----------------------|-----------------------------|------------------------------------|----------|
| R67 (43h)<br>SE1_LHPF_<br>R | 15:0 | SE1_LHPF_R<br>[15:0] | 0000_0000<br>_0000_000<br>0 | SE1_LHPF right channel coefficient |          |

Register 43h SE1\_LHPF\_R

| REGISTER  | BIT | LABEL                  | DEFAULT | DESCRIPTION                                           | REFER TO |
|-----------|-----|------------------------|---------|-------------------------------------------------------|----------|
| ADDRESS   |     |                        |         |                                                       |          |
| R68 (44h) | 12  | SE1_3D_MON             | 0       | SE1_3D_MONO:                                          |          |
| SE1_3D_C  |     | 0                      |         | 0 : L, R configs active                               |          |
| ONFIG     |     |                        |         | 1 : L config applied to both L and R                  |          |
|           | 9   | SE1_3D_R_SI            | 0       | SE1_3D_R_SIGN                                         |          |
|           |     | GN                     |         | 0 : add cross path values                             |          |
|           |     |                        |         | 1 : sub cross path values                             |          |
|           | 8   | SE1_3D_L_SI            | 0       | SE1_3D_L_SIGN                                         |          |
|           |     | GN                     |         | 0 : add cross path values                             |          |
|           |     |                        |         | 1 : sub cross path values                             |          |
|           | 7   | SE1_3D_LHPF            | 0       | SE1_3D_LHPF_R_ENA:                                    |          |
|           |     | _R_ENA                 |         | 0 : R channel disabled (bypass coeffs applied)        |          |
|           |     |                        |         | 1 : R channel enabled (bank coeffs applied)           |          |
|           | 6   | SE1_3D_LHPF<br>_L_ENA  | . 0     | SE1_3D_LHPF_L_ENA:                                    |          |
|           |     |                        |         | 0 : L channel disabled (bypass coeffs applied)        |          |
|           |     |                        |         | 1 : L channel enabled (bank coeffs applied)           |          |
|           | 5   | SE1_3D_R_LH<br>PF_SIGN | 0       | SE1_3D_R_LHPF_SIGN                                    |          |
|           |     |                        |         | 0 : sum internal result (LPF)                         |          |
|           |     |                        |         | 1 : sub internal result (HPF)                         |          |
|           | 4   | SE1_3D_L_LH            | 0       | SE1_3D_L_LHPF_SIGN                                    |          |
|           |     | PF_SIGN                |         | 0 : sum internal result (LPF)                         |          |
|           |     |                        |         | 1 : sub internal result (HPF)                         |          |
|           | 1   | SE1_3D_R_EN            | 0       | SE1 Right channel 3D stereo enhancement filter enable |          |
|           |     | Α                      |         | 0 = Disabled                                          |          |
|           |     |                        |         | 1 = Enabled                                           |          |
|           | 0   | SE1_3D_L_EN            | 0       | SE1 Left channel 3D stereo enhancement filter enable  |          |
|           |     | Α                      |         | 0 = Disabled                                          |          |
|           |     |                        |         | 1 = Enabled                                           |          |

Register 44h SE1\_3D\_CONFIG

| REGISTER  | BIT   | LABEL                    | DEFAULT | DESCRIPTION                              | REFER TO |
|-----------|-------|--------------------------|---------|------------------------------------------|----------|
| ADDRESS   |       |                          |         |                                          |          |
| R69 (45h) | 13:11 | SE1_3D_L_DE              | 000     | Sets the number of delay samples:        |          |
| SE1_3D_L  |       | LAY[2:0]                 |         | 0000 = 0                                 |          |
|           |       |                          |         | 0001 = 1                                 |          |
|           |       |                          |         | 0010 = 2                                 |          |
|           |       |                          |         | 0011 = 3                                 |          |
|           |       |                          |         | 0100 = 4                                 |          |
|           | 10:8  | SE1_3D_L_CU<br>TOFF[2:0] | 100     | Cut Off Frequency                        |          |
|           |       |                          |         | 0000 = 50Hz                              |          |
|           |       |                          |         | 0001 = 100Hz                             |          |
|           |       |                          |         | 0010 = 200Hz                             |          |
|           |       |                          |         | 0011 = 400 Hz                            |          |
|           |       |                          |         | 0100 = 1KHz                              |          |
|           |       |                          |         | 0101 = 2KHz                              |          |
|           |       |                          |         | 0110 = 4KHz                              |          |
|           |       |                          |         | 0111 = 10KHz                             |          |
|           |       |                          |         | 1000 to 1111 = reserved                  |          |
|           | 7:4   | SE1_3D_L_CG<br>AIN[3:0]  | 0000    | SE1 3D Left Channel cross gain setting   |          |
|           |       |                          |         | 0000 = -12dB                             |          |
|           |       |                          |         | 0001 = -10.5db                           |          |
|           |       |                          |         |                                          |          |
|           |       |                          |         | 1000= 0dB                                |          |
|           |       |                          |         | 1001 to 1111 = reserved                  |          |
|           | 3:0   | SE1_3D_L_FG              | 1000    | SE1 3D Left Channel forward gain setting |          |
|           |       | AIN[3:0]                 |         | 0000 = -12dB                             |          |
|           |       |                          |         | 0001 = -10.5db                           |          |
|           |       |                          |         |                                          |          |
|           |       |                          |         | 1000= 0dB                                |          |
|           |       |                          |         | 1001 to 1111 = reserved                  |          |

Register 45h SE1\_3D\_L

| REGISTER  | BIT   | LABEL                    | DEFAULT | DESCRIPTION                             | REFER TO |
|-----------|-------|--------------------------|---------|-----------------------------------------|----------|
| ADDRESS   |       |                          |         |                                         |          |
| R70 (46h) | 13:11 | SE1_3D_R_DE              | 000     | Sets the number of delay samples:       |          |
| SE1_3D_R  |       | LAY[2:0]                 |         | 0000 = 0                                |          |
|           |       |                          |         | 0001 = 1                                |          |
|           |       |                          |         | 0010 = 2                                |          |
|           |       |                          |         | 0011 = 3                                |          |
|           |       |                          |         | 0100 = 4                                |          |
|           | 10:8  | SE1_3D_R_CU<br>TOFF[2:0] | 100     | Cut Off Frequency                       |          |
|           |       |                          |         | 0000 = 50Hz                             |          |
|           |       |                          |         | 0001 = 100Hz                            |          |
|           |       |                          |         | 0010 = 200Hz                            |          |
|           |       |                          |         | 0011 = 400 Hz                           |          |
|           |       |                          |         | 0100 = 1KHz                             |          |
|           |       |                          |         | 0101 = 2KHz                             |          |
|           |       |                          |         | 0110 = 4KHz                             |          |
|           |       |                          |         | 0111 = 10KHz                            |          |
|           |       |                          |         | 1000 to 1111 = reserved                 |          |
|           | 7:4   | SE1_3D_R_C<br>GAIN[3:0]  | 0000    | SE1 3D Right Channel cross gain setting |          |
|           |       |                          |         | 0000 = -12dB                            |          |
|           |       |                          |         | 0001 = -10.5db                          |          |



| REGISTER<br>ADDRESS | BIT | LABEL                   | DEFAULT | DESCRIPTION                                                                                                         | REFER TO |
|---------------------|-----|-------------------------|---------|---------------------------------------------------------------------------------------------------------------------|----------|
|                     |     |                         |         | <br>1000= 0dB<br>1001 to 1111 = reserved                                                                            |          |
|                     | 3:0 | SE1_3D_R_FG<br>AIN[3:0] | 1000    | SE1 3D Right Channel forward gain setting $0000 = -12 dB$ $0001 = -10.5 db$ $1000 = 0 dB$ $1001 to 1111 = reserved$ |          |

Register 46h SE1\_3D\_R

| REGISTER  | BIT | LABEL      | DEFAULT | DESCRIPTION                            | REFER TO |
|-----------|-----|------------|---------|----------------------------------------|----------|
| ADDRESS   |     |            |         |                                        |          |
| R71 (47h) | 1   | SE1_NOTCH_ | 0       | SE1 Right channel notch filters enable |          |
| SE1_NOTC  |     | R_ENA      |         | 0 = Disabled                           |          |
| H_CONFIG  |     |            |         | 1 = Enabled                            |          |
|           | 0   | SE1_NOTCH_ | 0       | SE1 Left channel notch filters enable  |          |
|           |     | L_ENA      |         | 0 = Disabled                           |          |
|           |     |            |         | 1 = Enabled                            |          |

Register 47h SE1\_NOTCH\_CONFIG

| REGISTER                       | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------------------|-----------------------------------------------------------------|----------|
| ADDRESS                        |      |                         |                     |                                                                 |          |
| R72 (48h)<br>SE1_NOTC<br>H_A10 | 15:0 | SE1_NOTCH_<br>A10[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 48h SE1\_NOTCH\_A10

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| R73 (49h)<br>SE1_NOTC<br>H A11 | 15:0 | SE1_NOTCH_<br>A11[15:0] |         | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 49h SE1\_NOTCH\_A11

| REGISTER<br>ADDRESS   | BIT  | LABEL                   | DEFAULT      | DESCRIPTION                                                     | REFER TO |
|-----------------------|------|-------------------------|--------------|-----------------------------------------------------------------|----------|
| R74 (4Ah)<br>SE1_NOTC | 15:0 | SE1_NOTCH_<br>A20[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |
| H_A20                 |      |                         | 0            |                                                                 |          |

Register 4Ah SE1\_NOTCH\_A20

| REGISTER  | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|-----------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS   |      |            |           |                                                    |          |
| R75 (4Bh) | 15:0 | SE1_NOTCH_ | 0000_0000 | Filter coefficients for Signal Enhancement 1 (SE1) |          |
| SE1_NOTC  |      | A21[15:0]  | _0000_000 | notch filter                                       |          |
| H_A21     |      |            | 0         |                                                    |          |

Register 4Bh SE1\_NOTCH\_A21



| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT      | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|--------------|-----------------------------------------------------------------|----------|
| R76 (4Ch)<br>SE1_NOTC<br>H_A30 | 15:0 | SE1_NOTCH_<br>A30[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 4Ch SE1\_NOTCH\_A30

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT           | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|-------------------|-----------------------------------------------------------------|----------|
| R77 (4Dh)<br>SE1_NOTC<br>H A31 | 15:0 | SE1_NOTCH_<br>A31[15:0] | - · · · · · - · · | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 4Dh SE1\_NOTCH\_A31

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT           | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|-------------------|-----------------------------------------------------------------|----------|
| R78 (4Eh)<br>SE1_NOTC<br>H_A40 | 15:0 | SE1_NOTCH_<br>A40[15:0] | - · · · · · - · · | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 4Eh SE1\_NOTCH\_A40

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------------------|-----------------------------------------------------------------|----------|
| R79 (4Fh)<br>SE1_NOTC<br>H_A41 | 15:0 | SE1_NOTCH_<br>A41[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 4Fh SE1\_NOTCH\_A41

| REGISTER                       | BIT  | LABEL                   | DEFAULT      | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|--------------|-----------------------------------------------------------------|----------|
| ADDRESS                        |      |                         |              |                                                                 |          |
| R80 (50h)<br>SE1_NOTC<br>H_A50 | 15:0 | SE1_NOTCH_<br>A50[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 50h SE1\_NOTCH\_A50

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT      | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|--------------|-----------------------------------------------------------------|----------|
| R81 (51h)<br>SE1_NOTC<br>H A51 | 15:0 | SE1_NOTCH_<br>A51[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 51h SE1\_NOTCH\_A51

| REGISTER<br>ADDRESS | BIT  | LABEL     | DEFAULT      | DESCRIPTION                                        | REFER TO |
|---------------------|------|-----------|--------------|----------------------------------------------------|----------|
| R82 (52h)           | 15:0 |           | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) |          |
| SE1_NOTC<br>H_M10   |      | M10[15:0] | _0000_000    | notch filter                                       |          |

Register 52h SE1\_NOTCH\_M10



| REGISTER                       | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| ADDRESS                        |      |                         |         |                                                                 |          |
| R83 (53h)<br>SE1_NOTC<br>H_M11 | 15:0 | SE1_NOTCH_<br>M11[15:0] |         | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 53h SE1\_NOTCH\_M11

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT      | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|--------------|-----------------------------------------------------------------|----------|
| R84 (54h)<br>SE1_NOTC<br>H_M20 | 15:0 | SE1_NOTCH_<br>M20[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 54h SE1\_NOTCH\_M20

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| R85 (55h)<br>SE1_NOTC<br>H M21 | 15:0 | SE1_NOTCH_<br>M21[15:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 55h SE1\_NOTCH\_M21

| REGISTER              | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|-----------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| ADDRESS               |      |                         |         |                                                                 |          |
| R86 (56h)<br>SE1 NOTC | 15:0 | SE1_NOTCH_<br>M30[15:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |
| H_M30                 |      | [0.61]06IVI             | 0       | Tiotal line                                                     |          |

Register 56h SE1\_NOTCH\_M30

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| R87 (57h)<br>SE1_NOTC<br>H_M31 | 15:0 | SE1_NOTCH_<br>M31[15:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 57h SE1\_NOTCH\_M31

| REGISTER<br>ADDRESS   | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|-----------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| R88 (58h)<br>SE1_NOTC | 15:0 | SE1_NOTCH_<br>M40[15:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |
| H_M40                 |      | _ •                     | 0       |                                                                 |          |

Register 58h SE1\_NOTCH\_M40

| REGISTER<br>ADDRESS            | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                     | REFER TO |
|--------------------------------|------|-------------------------|---------|-----------------------------------------------------------------|----------|
| R89 (59h)<br>SE1_NOTC<br>H_M41 | 15:0 | SE1_NOTCH_<br>M41[15:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |

Register 59h SE1\_NOTCH\_M41



| REGISTER              | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                     | REFER TO |
|-----------------------|------|-------------------------|---------------------|-----------------------------------------------------------------|----------|
| ADDRESS               |      |                         |                     |                                                                 |          |
| R90 (5Ah)<br>SE1_NOTC | 15:0 | SE1_NOTCH_<br>M50[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 1 (SE1) notch filter |          |
| H_M50                 |      |                         | 0                   |                                                                 |          |

Register 5Ah SE1\_NOTCH\_M50

| REGISTER  | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|-----------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS   |      |            |           |                                                    |          |
| R91 (5Bh) | 15:0 | SE1_NOTCH_ | 0001_0000 | Filter coefficients for Signal Enhancement 1 (SE1) |          |
| SE1_NOTC  |      | M51[15:0]  | _0000_000 | notch filter                                       |          |
| H_M51     |      |            | 0         |                                                    |          |

Register 5Bh SE1\_NOTCH\_M51

| REGISTER  | BIT | LABEL       | DEFAULT | DESCRIPTION                         | REFER TO |
|-----------|-----|-------------|---------|-------------------------------------|----------|
| ADDRESS   |     |             |         |                                     |          |
| R92 (5Ch) | 1   | SE1_DF1_R_E | 0       | SE1 Right channel DF1 filter enable |          |
| SE1_DF1_C |     | NA          |         | 0 = Disabled                        |          |
| ONFIG     |     |             |         | 1 = Enabled                         |          |
|           | 0   | SE1_DF1_L_E | 0       | SE1 Left channel DF1 filter enable  |          |
|           |     | NA          |         | 0 = Disabled                        |          |
|           |     |             |         | 1 = Enabled                         |          |

Register 5Ch SE1\_DF1\_CONFIG

| REGISTER  | BIT  | LABEL        | DEFAULT   | DESCRIPTION                                             | REFER TO |
|-----------|------|--------------|-----------|---------------------------------------------------------|----------|
| ADDRESS   |      |              |           |                                                         |          |
| R93 (5Dh) | 15:0 | SE1_DF1_L0[1 | 0001_0000 | Filter coefficients for Signal Enhancement 1 (SE1) left |          |
| SE1_DF1_L |      | 5:0]         | _0000_000 | channel DF1 filter                                      |          |
| 0         |      |              | 0         |                                                         |          |

Register 5Dh SE1\_DF1\_L0

| REGISTER  | BIT  | LABEL        | DEFAULT   | DESCRIPTION                                             | REFER TO |
|-----------|------|--------------|-----------|---------------------------------------------------------|----------|
| ADDRESS   |      |              |           |                                                         |          |
| R94 (5Eh) | 15:0 | SE1_DF1_L1[1 | 0000_0000 | Filter coefficients for Signal Enhancement 1 (SE1) left |          |
| SE1_DF1_L |      | 5:0]         | _0000_000 | channel DF1 filter                                      |          |
| 1         |      |              | 0         |                                                         |          |

Register 5Eh SE1\_DF1\_L1

| REGISTER  | BIT  | LABEL        | DEFAULT   | DESCRIPTION                                             | REFER TO |
|-----------|------|--------------|-----------|---------------------------------------------------------|----------|
| ADDRESS   |      |              |           |                                                         |          |
| R95 (5Fh) | 15:0 | SE1_DF1_L2[1 | 0000_0000 | Filter coefficients for Signal Enhancement 1 (SE1) left |          |
| SE1_DF1_L |      | 5:0]         | _0000_000 | channel DF1 filter                                      |          |
| 2         |      |              | 0         |                                                         |          |

Register 5Fh SE1\_DF1\_L2



| REGISTER<br>ADDRESS         | BIT  | LABEL                | DEFAULT  | DESCRIPTION                                                                 | REFER TO |
|-----------------------------|------|----------------------|----------|-----------------------------------------------------------------------------|----------|
| R96 (60h)<br>SE1_DF1_R<br>0 | 15:0 | SE1_DF1_R0[1<br>5:0] | <b>-</b> | Filter coefficients for Signal Enhancement 1 (SE1) right channel DF1 filter |          |

Register 60h SE1\_DF1\_R0

| REGISTER<br>ADDRESS         | BIT  | LABEL                | DEFAULT | DESCRIPTION                                                                 | REFER TO |
|-----------------------------|------|----------------------|---------|-----------------------------------------------------------------------------|----------|
| R97 (61h)<br>SE1_DF1_R<br>1 | 15:0 | SE1_DF1_R1[1<br>5:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) right channel DF1 filter |          |

Register 61h SE1\_DF1\_R1

| REGISTER<br>ADDRESS         | BIT  | LABEL                | DEFAULT | DESCRIPTION                                                                 | REFER TO |
|-----------------------------|------|----------------------|---------|-----------------------------------------------------------------------------|----------|
| R98 (62h)<br>SE1_DF1_R<br>2 | 15:0 | SE1_DF1_R2[1<br>5:0] | _       | Filter coefficients for Signal Enhancement 1 (SE1) right channel DF1 filter |          |

Register 62h SE1\_DF1\_R2

| REGISTER   | BIT | LABEL      | DEFAULT | DESCRIPTION                             | REFER TO |
|------------|-----|------------|---------|-----------------------------------------|----------|
| ADDRESS    |     |            |         |                                         |          |
| R100 (64h) | 1   | SE2_RETUNE | 0       | SE2 Right channel ReTune™ filter enable |          |
| SE2_RETU   |     | _R_ENA     |         | 0 = Disabled                            |          |
| NE_CONFI   |     |            |         | 1 = Enabled                             |          |
| G          | 0   | SE2_RETUNE | 0       | SE2 Left channel ReTune™ filter enable  |          |
|            |     | _L_ENA     |         | 0 = Disabled                            |          |
|            |     |            |         | 1 = Enabled                             |          |

Register 64h SE2\_RETUNE\_CONFIG

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|---------|----------------------------------------------------------------------|----------|
| R101 (65h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C0[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C0                  |      |                         | 0       |                                                                      |          |

Register 65h SE2\_RETUNE\_C0

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT           | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|-------------------|----------------------------------------------------------------------|----------|
| R102 (66h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C1[15:0] | - · · · · · - · · | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE C1                  |      |                         | 0                 |                                                                      |          |

Register 66h SE2\_RETUNE\_C1

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|---------------------|----------------------------------------------------------------------|----------|
| R103 (67h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C2[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C2                  |      |                         | 0                   |                                                                      |          |

Register 67h SE2\_RETUNE\_C2



| REGISTER   | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|------------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS    |      |            |           |                                                    |          |
| R104 (68h) | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU   |      | _C3[15:0]  | _0000_000 | ReTune™ filter                                     |          |
| NE_C3      |      |            | 0         |                                                    |          |

Register 68h SE2\_RETUNE\_C3

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|---------------------|----------------------------------------------------------------------|----------|
| R105 (69h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C4[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE C4                  |      |                         |                     |                                                                      |          |

Register 69h SE2\_RETUNE\_C4

| REGISTER<br>ADDRESS             | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|---------------------------------|------|-------------------------|---------------------|----------------------------------------------------------------------|----------|
| R106 (6Ah)<br>SE2_RETU<br>NE_C5 | 15:0 | SE2_RETUNE<br>_C5[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 6Ah SE2\_RETUNE\_C5

| REGISTER<br>ADDRESS    | BIT  | LABEL                  | DEFAULT             | DESCRIPTION                                                       | REFER TO |
|------------------------|------|------------------------|---------------------|-------------------------------------------------------------------|----------|
| R107 (6Bh)<br>SE2 RETU | 15:0 | SE2_RETUNE<br>C6[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2) ReTune™ filter |          |
| NE_C6                  |      | ,                      | 0                   |                                                                   |          |

Register 6Bh SE2\_RETUNE\_C6

| REGISTER<br>ADDRESS | BIT  | LABEL      | DEFAULT                  | DESCRIPTION                                        | REFER TO |
|---------------------|------|------------|--------------------------|----------------------------------------------------|----------|
| R108 (6Ch)          | 15:0 | SE2_RETUNE | - · · · <u>-</u> · · · · | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU            |      | _C7[15:0]  | _0000_000                | ReTune™ filter                                     |          |
| NE_C7               |      |            | 0                        |                                                    |          |

Register 6Ch SE2\_RETUNE\_C7

| REGISTER<br>ADDRESS    | BIT  | LABEL                  | DEFAULT       | DESCRIPTION                                                          | REFER TO |
|------------------------|------|------------------------|---------------|----------------------------------------------------------------------|----------|
| R109 (6Dh)<br>SE2 RETU | 15:0 | SE2_RETUNE<br>C8[15:0] | - · · · · · - | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE C8                  |      |                        | 0             |                                                                      |          |

Register 6Dh SE2\_RETUNE\_C8

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT                        | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|--------------------------------|----------------------------------------------------------------------|----------|
| R110 (6Eh)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C9[15:0] | - · · · · <del>-</del> · · · · | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C9                  |      |                         | 0                              |                                                                      |          |

Register 6Eh SE2\_RETUNE\_C9



| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT       | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------------|----------------------------------------------------------------------|----------|
| R111 (6Fh)<br>SE2_RETU<br>NE_C10 | 15:0 | SE2_RETUNE<br>_C10[15:0] | - · · · · · - | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 6Fh SE2\_RETUNE\_C10

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT                        | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|--------------------------------|----------------------------------------------------------------------|----------|
| R112 (70h)<br>SE2_RETU<br>NE_C11 | 15:0 | SE2_RETUNE<br>_C11[15:0] | - · · · · <del>-</del> · · · · | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 70h SE2\_RETUNE\_C11

| LABEL                    | DEFAULT    | DESCRIPTION            | REFER TO                                                                |
|--------------------------|------------|------------------------|-------------------------------------------------------------------------|
|                          |            |                        |                                                                         |
| SE2_RETUNE<br>_C12[15:0] | _          | ,                      |                                                                         |
| )                        | SE2_RETUNE | ) SE2_RETUNE 0000_0000 | SE2_RETUNE 0000_0000 Filter coefficients for Signal Enhancement 2 (SE2) |

Register 71h SE2\_RETUNE\_C12

| REGISTER   | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|------------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS    |      |            |           |                                                    |          |
| R114 (72h) | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU   |      | _C13[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C13     |      |            | 0         |                                                    |          |

Register 72h SE2\_RETUNE\_C13

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|---------|----------------------------------------------------------------------|----------|
| R115 (73h)<br>SE2 RETU | 15:0 | SE2_RETUNE<br>C14[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C14                 |      | _014[10.0]              | 0       | Tre rune lines                                                       |          |

Register 73h SE2\_RETUNE\_C14

| REGISTER<br>ADDRESS | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|---------------------|------|------------|-----------|----------------------------------------------------|----------|
| R116 (74h)          | 15:0 | _          | _         | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU<br>NE_C15  |      | _C15[15:0] | _0000_000 | ReTune™ filter                                     |          |

Register 74h SE2\_RETUNE\_C15

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------|----------------------------------------------------------------------|----------|
| R117 (75h)<br>SE2_RETU<br>NE_C16 | 15:0 | SE2_RETUNE<br>_C16[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 75h SE2\_RETUNE\_C16



| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------------------|----------------------------------------------------------------------|----------|
| R118 (76h)<br>SE2_RETU<br>NE_C17 | 15:0 | SE2_RETUNE<br>_C17[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 76h SE2\_RETUNE\_C17

| REGISTER<br>ADDRESS    | BIT  | LABEL                    | DEFAULT                        | DESCRIPTION                                                          | REFER TO |
|------------------------|------|--------------------------|--------------------------------|----------------------------------------------------------------------|----------|
| R119 (77h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C18[15:0] | - · · · · <del>-</del> · · · · | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C18                 |      |                          | 0                              |                                                                      |          |

Register 77h SE2\_RETUNE\_C18

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------------------|----------------------------------------------------------------------|----------|
| R120 (78h)<br>SE2_RETU<br>NE_C19 | 15:0 | SE2_RETUNE<br>_C19[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 78h SE2\_RETUNE\_C19

| REGISTER<br>ADDRESS    | BIT  | LABEL                   | DEFAULT             | DESCRIPTION                                                          | REFER TO |
|------------------------|------|-------------------------|---------------------|----------------------------------------------------------------------|----------|
| R121 (79h)<br>SE2 RETU | 15:0 | SE2_RETUNE<br>C20[15:0] | _ · · · · _ · · · . | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C20                 |      |                         |                     |                                                                      |          |

Register 79h SE2\_RETUNE\_C20

| REGISTER   | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|------------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS    |      |            |           |                                                    |          |
| R122 (7Ah) | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU   |      | _C21[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C21     |      |            | 0         |                                                    |          |

Register 7Ah SE2\_RETUNE\_C21

| REGISTER<br>ADDRESS | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|---------------------|------|------------|-----------|----------------------------------------------------|----------|
| R123 (7Bh)          | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU            |      | _C22[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C22              |      |            | 0         |                                                    |          |

Register 7Bh SE2\_RETUNE\_C22

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT       | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------------|----------------------------------------------------------------------|----------|
| R124 (7Ch)<br>SE2_RETU<br>NE C23 | 15:0 | SE2_RETUNE<br>_C23[15:0] | - · · · · · - | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 7Ch SE2\_RETUNE\_C23



| REGISTE:                       |   | LABEL                    | DEFAULT                        | DESCRIPTION                                                          | REFER TO |
|--------------------------------|---|--------------------------|--------------------------------|----------------------------------------------------------------------|----------|
| R125 (7Dr<br>SE2_RET<br>NE_C24 | , | SE2_RETUNE<br>_C24[15:0] | - · · · · <del>-</del> · · · · | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 7Dh SE2\_RETUNE\_C24

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT       | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------------|----------------------------------------------------------------------|----------|
| R126 (7Eh)<br>SE2_RETU<br>NE_C25 | 15:0 | SE2_RETUNE<br>_C25[15:0] | - · · · · · - | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 7Eh SE2\_RETUNE\_C25

| REGISTER   | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|------------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS    |      |            |           |                                                    |          |
| R127 (7Fh) | 15:0 | _          | _         | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU   |      | _C26[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C26     |      |            | 0         |                                                    |          |

Register 7Fh SE2\_RETUNE\_C26

| REGISTER   | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|------------|------|------------|-----------|----------------------------------------------------|----------|
| ADDRESS    |      |            |           |                                                    |          |
| R128 (80h) | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU   |      | _C27[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C27     |      |            | 0         |                                                    |          |

Register 80h SE2\_RETUNE\_C27

| REGISTER<br>ADDRESS    | BIT  | LABEL                    | DEFAULT | DESCRIPTION                                                          | REFER TO |
|------------------------|------|--------------------------|---------|----------------------------------------------------------------------|----------|
| R129 (81h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C28[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C28                 |      |                          | 0       |                                                                      |          |

Register 81h SE2\_RETUNE\_C28

| REGISTER<br>ADDRESS | BIT  | LABEL      | DEFAULT   | DESCRIPTION                                        | REFER TO |
|---------------------|------|------------|-----------|----------------------------------------------------|----------|
| R130 (82h)          | 15:0 | SE2_RETUNE | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) |          |
| SE2_RETU            |      | _C29[15:0] | _0000_000 | ReTune™ filter                                     |          |
| NE_C29              |      |            | 0         |                                                    |          |

Register 82h SE2\_RETUNE\_C29

| REGISTER<br>ADDRESS              | BIT  | LABEL                    | DEFAULT | DESCRIPTION                                                          | REFER TO |
|----------------------------------|------|--------------------------|---------|----------------------------------------------------------------------|----------|
| R131 (83h)<br>SE2_RETU<br>NE_C30 | 15:0 | SE2_RETUNE<br>_C30[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |

Register 83h SE2\_RETUNE\_C30



| REGISTER<br>ADDRESS    | BIT  | LABEL                    | DEFAULT      | DESCRIPTION                                                          | REFER TO |
|------------------------|------|--------------------------|--------------|----------------------------------------------------------------------|----------|
| R132 (84h)<br>SE2_RETU | 15:0 | SE2_RETUNE<br>_C31[15:0] | <del>-</del> | Filter coefficients for Signal Enhancement 2 (SE2)<br>ReTune™ filter |          |
| NE_C31                 |      |                          | 0            |                                                                      |          |

Register 84h SE2\_RETUNE\_C31

| REGISTER                | BIT | LABEL              | DEFAULT | DESCRIPTION                                       | REFER TO |
|-------------------------|-----|--------------------|---------|---------------------------------------------------|----------|
| ADDRESS                 |     |                    |         |                                                   |          |
| R133 (85h)<br>SE2_5BEQ_ | 0   | SE2_5BEQ_L_<br>ENA | 0       | SE2 Left channel 5-band EQ enable<br>0 = Disabled |          |
| CONFIG                  |     |                    |         | 1 = Enabled                                       |          |

Register 85h SE2\_5BEQ\_CONFIG

| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT | DESCRIPTION                                             | REFER TO |
|---------------------|------|-------------|---------|---------------------------------------------------------|----------|
| R134 (86h)          | 12:8 | SE2_5BEQ_L1 | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_<br>L10G   |      | G[4:0]      |         | channel 5-band EQ filter Gain                           |          |
| LIUG                |      |             |         | 00000 : -12dB                                           |          |
|                     |      |             |         | 00001 : -12dB                                           |          |
|                     |      |             |         | 00010 : -10dB                                           |          |
|                     |      |             |         | 00011:-9dB                                              |          |
|                     |      |             |         | 00100 : -8dB                                            |          |
|                     |      |             |         | 00101:-7dB                                              |          |
|                     |      |             |         | 00110 : -6dB                                            |          |
|                     |      |             |         | 00111 : -5dB                                            |          |
|                     |      |             |         | 01000 : -4dB                                            |          |
|                     |      |             |         | 01001 : -3dB                                            |          |
|                     |      |             |         | 01010 : -2dB                                            |          |
|                     |      |             |         | 01011 : -1dB                                            |          |
|                     |      |             |         | 01100 : 0dB                                             |          |
|                     |      |             |         | 01101 : 1dB                                             |          |
|                     |      |             |         | 01110 : 2dB                                             |          |
|                     |      |             |         | 01111 : 3dB                                             |          |
|                     |      |             |         | 10000 : 4dB                                             |          |
|                     |      |             |         | 10001 : 5dB                                             |          |
|                     |      |             |         | 10010 : 6dB                                             |          |
|                     |      |             |         | 10011 : 7dB                                             |          |
|                     |      |             |         | 10100 : 8dB                                             |          |
|                     |      |             |         | 10101 : 9dB                                             |          |
|                     |      |             |         | 10110 : 10dB                                            |          |
|                     |      |             |         | 10111 : 11dB                                            |          |
|                     |      |             |         | 11000 : 12dB                                            |          |
|                     |      |             |         | 11001 to 11111 : Reserved                               |          |
|                     | 4:0  | SE2_5BEQ_L0 | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
|                     |      | G[4:0]      |         | channel 5-band EQ filter Gain                           |          |
|                     |      |             |         | 00000 : -12dB                                           |          |
|                     |      |             |         | 00001 : -12dB                                           |          |
|                     |      |             |         | 00010 : -10dB                                           |          |
|                     |      |             |         | 00011 : -9dB                                            |          |
|                     |      |             |         | (1dB steps)                                             |          |
|                     |      |             |         | 11000 : 12dB                                            |          |
|                     |      |             |         | 11001 to 11111 : Reserved                               |          |



# Register 86h SE2\_5BEQ\_L10G

| REGISTER   | BIT  | LABEL       | DEFAULT | DESCRIPTION                                             | REFER TO |
|------------|------|-------------|---------|---------------------------------------------------------|----------|
| ADDRESS    |      |             |         |                                                         |          |
| R135 (87h) | 12:8 | SE2_5BEQ_L3 | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_  |      | G[4:0]      |         | channel 5-band EQ filter Gain                           |          |
| L32G       |      |             |         | 00000 : -12dB                                           |          |
|            |      |             |         | 00001 : -12dB                                           |          |
|            |      |             |         | 00010 : -10dB                                           |          |
|            |      |             |         | 00011:-9dB                                              |          |
|            |      |             |         | (1dB steps)                                             |          |
|            |      |             |         | 11000 : 12dB                                            |          |
|            |      |             |         | 11001 to 11111 : Reserved                               |          |
|            | 4:0  | SE2_5BEQ_L2 | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
|            |      | G[4:0]      |         | channel 5-band EQ filter Gain                           |          |
|            |      |             |         | 00000 : -12dB                                           |          |
|            |      |             |         | 00001 : -12dB                                           |          |
|            |      |             |         | 00010 : -10dB                                           |          |
|            |      |             |         | 00011:-9dB                                              |          |
|            |      |             |         | (1dB steps)                                             |          |
|            |      |             |         | 11000 : 12dB                                            |          |
|            |      |             |         | 11001 to 11111 : Reserved                               |          |

Register 87h SE2\_5BEQ\_L32G

| REGISTER                       | BIT | LABEL                 | DEFAULT | DESCRIPTION                                                                                                                                                      | REFER TO |
|--------------------------------|-----|-----------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| ADDRESS                        |     |                       |         |                                                                                                                                                                  |          |
| R136 (88h)<br>SE2_5BEQ_<br>L4G | 4:0 | SE2_5BEQ_L4<br>G[4:0] | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter Gain 00000: -12dB 00001: -12dB 00010: -10dB 00011: -9dB (1dB steps) 11000: 12dB |          |
|                                |     |                       |         | 11000 : 120B<br>11001 to 11111 : Reserved                                                                                                                        |          |

Register 88h SE2\_5BEQ\_L4G

| REGISTER   | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                             | REFER TO |
|------------|------|-------------|-----------|---------------------------------------------------------|----------|
| ADDRESS    |      |             |           |                                                         |          |
| R137 (89h) | 15:0 | SE2_5BEQ_L0 | 0000_0000 | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_  |      | P[15:0]     | _1101_100 | channel 5-band EQ filter                                |          |
| L0P        |      |             | 0         |                                                         |          |

Register 89h SE2\_5BEQ\_L0P

| REGISTER   | BIT  | LABEL   | DEFAULT   | DESCRIPTION                                             | REFER TO |
|------------|------|---------|-----------|---------------------------------------------------------|----------|
| ADDRESS    |      |         |           |                                                         |          |
| R138 (8Ah) | 15:0 |         | _         | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_  |      | A[15:0] | _1100_101 | channel 5-band EQ filter                                |          |
| L0A        |      |         | 0         |                                                         |          |

Register 8Ah SE2\_5BEQ\_L0A



| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R139 (8Bh)<br>SE2_5BEQ_<br>L0B | 15:0 | SE2_5BEQ_L0<br>B[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 8Bh SE2\_5BEQ\_L0B

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R140 (8Ch)<br>SE2_5BEQ_<br>L1P | 15:0 | SE2_5BEQ_L1<br>P[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 8Ch SE2\_5BEQ\_L1P

| REGISTER                       | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |         |                                                                                  |          |
| R141 (8Dh)<br>SE2_5BEQ_<br>L1A | 15:0 | SE2_5BEQ_L1<br>A[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 8Dh SE2\_5BEQ\_L1A

| REGISTER                | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|-------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| ADDRESS                 |      |                        |         |                                                                                  |          |
| R142 (8Eh)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_L1<br>B[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |
| L1B                     |      |                        | 1       |                                                                                  |          |

Register 8Eh SE2\_5BEQ\_L1B

| REGISTER   | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                             | REFER TO |
|------------|------|-------------|-----------|---------------------------------------------------------|----------|
| ADDRESS    |      |             |           |                                                         |          |
| R143 (8Fh) | 15:0 | SE2_5BEQ_L1 | - · · · · | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_  |      | C[15:0]     | _0111_010 | channel 5-band EQ filter                                |          |
| L1C        |      |             | 1         |                                                         |          |

Register 8Fh SE2\_5BEQ\_L1C

| REGISTER                | BIT  | LABEL                  | DEFAULT         | DESCRIPTION                                                                      | REFER TO |
|-------------------------|------|------------------------|-----------------|----------------------------------------------------------------------------------|----------|
| ADDRESS                 |      |                        |                 |                                                                                  |          |
| R144 (90h)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_L2<br>P[15:0] | _ · · · · _ · · | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |
| L2P                     |      |                        | 0               |                                                                                  |          |

Register 90h SE2\_5BEQ\_L2P

| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                             | REFER TO |
|---------------------|------|-------------|-----------|---------------------------------------------------------|----------|
| R145 (91h)          | 15:0 | SE2_5BEQ_L2 | 0001_1100 | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_           |      | A[15:0]     | _0101_100 | channel 5-band EQ filter                                |          |
| L2A                 |      |             | 0         |                                                         | ļ        |

Register 91h SE2\_5BEQ\_L2A



| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R146 (92h)<br>SE2_5BEQ_<br>L2B | 15:0 | SE2_5BEQ_L2<br>B[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 92h SE2\_5BEQ\_L2B

| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|-------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R147 (93h)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_L2<br>C[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |
| L2C                     |      |                        | 0       |                                                                                  |          |

Register 93h SE2\_5BEQ\_L2C

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R148 (94h)<br>SE2_5BEQ_<br>L3P | 15:0 | SE2_5BEQ_L3<br>P[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 94h SE2\_5BEQ\_L3P

| REGISTER                       | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |         |                                                                                  |          |
| R149 (95h)<br>SE2_5BEQ_<br>L3A | 15:0 | SE2_5BEQ_L3<br>A[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 95h SE2\_5BEQ\_L3A

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R150 (96h)<br>SE2_5BEQ_<br>L3B | 15:0 | SE2_5BEQ_L3<br>B[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 96h SE2\_5BEQ\_L3B

| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|-------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R151 (97h)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_L3<br>C[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |
| L3C                     |      |                        | 1       |                                                                                  |          |

Register 97h SE2\_5BEQ\_L3C

| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|-------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R152 (98h)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_L4<br>P[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |
| L4P                     |      |                        | 0       |                                                                                  |          |

Register 98h SE2\_5BEQ\_L4P



| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                      | REFER TO |
|--------------------------------|------|------------------------|---------|----------------------------------------------------------------------------------|----------|
| R153 (99h)<br>SE2_5BEQ_<br>L4A | 15:0 | SE2_5BEQ_L4<br>A[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) left channel 5-band EQ filter |          |

Register 99h SE2\_5BEQ\_L4A

| REGISTER   | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                             | REFER TO |
|------------|------|-------------|-----------|---------------------------------------------------------|----------|
| ADDRESS    |      |             |           |                                                         |          |
| R154 (9Ah) | 15:0 | SE2_5BEQ_L4 | 0000_0101 | Filter coefficients for Signal Enhancement 2 (SE2) left |          |
| SE2_5BEQ_  |      | B[15:0]     | _0101_100 | channel 5-band EQ filter                                |          |
| L4B        |      |             | 1         |                                                         |          |

Register 9Ah SE2\_5BEQ\_L4B

| REGISTER<br>ADDRESS | ВІТ    | LABEL                 | DEFAULT | DESCRIPTION                                                                            | REFER TO |
|---------------------|--------|-----------------------|---------|----------------------------------------------------------------------------------------|----------|
| R155 (9Bh)          | 12:8   | SE2_5BEQ_R1           | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) right                               |          |
| SE2_5BEQ_           |        | G[4:0]                | _       | channel 5-band EQ filter Gain                                                          |          |
| R10G                |        |                       |         | 00000 : -12dB                                                                          |          |
|                     |        |                       |         | 00001 : -12dB                                                                          |          |
|                     |        |                       |         | 00010 : -10dB                                                                          |          |
|                     |        |                       |         | 00011 : -9dB                                                                           |          |
|                     |        |                       |         | 00100 : -8dB                                                                           |          |
|                     |        |                       |         | 00101 : -7dB                                                                           |          |
|                     |        |                       |         | 00110 : -6dB                                                                           |          |
|                     |        |                       |         | 00111 : -5dB                                                                           |          |
|                     |        |                       |         | 01000 : -4dB                                                                           |          |
|                     |        |                       |         | 01001 : -3dB                                                                           |          |
|                     |        |                       |         | 01010 : -2dB                                                                           |          |
|                     |        |                       |         | 01011 : -1dB                                                                           |          |
|                     |        |                       |         | 01100 : 0dB                                                                            |          |
|                     |        |                       |         | 01101 : 1dB                                                                            |          |
|                     |        |                       |         | 01110 : 2dB                                                                            |          |
|                     |        |                       |         | 01111 : 3dB                                                                            |          |
|                     |        |                       |         | 10000 : 4dB                                                                            |          |
|                     |        |                       |         | 10001 : 5dB                                                                            |          |
|                     |        |                       |         | 10010 : 6dB                                                                            |          |
|                     |        |                       |         | 10011 : 7dB                                                                            |          |
|                     |        |                       |         | 10100 : 8dB                                                                            |          |
|                     |        |                       |         | 10101 : 9dB                                                                            |          |
|                     |        |                       |         | 10110 : 10dB                                                                           |          |
|                     |        |                       |         | 10111 : 11dB                                                                           |          |
|                     |        |                       |         | 11000 : 12dB                                                                           |          |
|                     |        |                       |         | 11001 to 11111 : Reserved                                                              |          |
|                     | 4:0    | SE2_5BEQ_R0<br>G[4:0] | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter Gain |          |
|                     |        |                       |         | 00000 : -12dB                                                                          |          |
|                     |        |                       |         | 00001 : -12dB                                                                          |          |
|                     |        |                       |         | 00010 : -10dB                                                                          |          |
|                     |        |                       |         | 00011 : -9dB                                                                           |          |
|                     |        |                       |         | (1dB steps)                                                                            |          |
|                     |        |                       |         | 11000 : 12dB                                                                           |          |
|                     |        |                       |         | 11001 to 11111 : Reserved                                                              |          |
| <u> </u>            | 050.50 | FO D400               |         |                                                                                        |          |

Register 9Bh SE2\_5BEQ\_R10G



| REGISTER                        | BIT  | LABEL                 | DEFAULT | DESCRIPTION                                                                                                                                                                                | REFER TO |
|---------------------------------|------|-----------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| ADDRESS                         |      |                       |         |                                                                                                                                                                                            |          |
| R156 (9Ch)<br>SE2_5BEQ_<br>R32G | 12:8 | SE2_5BEQ_R3<br>G[4:0] | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter Gain 00000: -12dB 00001: -12dB 00010: -10dB 00011: -9dB (1dB steps) 11000: 12dB 11001 to 11111: Reserved |          |
|                                 | 4:0  | SE2_5BEQ_R2<br>G[4:0] | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter Gain 00000: -12dB 00001: -12dB 00010: -10dB 00011: -9dB (1dB steps) 11000: 12dB 11001 to 11111: Reserved |          |

Register 9Ch SE2\_5BEQ\_R32G

| REGISTER                | BIT | LABEL                 | DEFAULT | DESCRIPTION                                                                            | REFER TO |
|-------------------------|-----|-----------------------|---------|----------------------------------------------------------------------------------------|----------|
| ADDRESS                 |     |                       |         |                                                                                        |          |
| R157 (9Dh)<br>SE2_5BEQ_ | 4:0 | SE2_5BEQ_R4<br>G[4:0] | 0_1100  | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter Gain |          |
| R4G                     |     |                       |         | 00000 : -12dB                                                                          |          |
|                         |     |                       |         | 00001 : -12dB                                                                          |          |
|                         |     |                       |         | 00010 : -10dB                                                                          |          |
|                         |     |                       |         | 00011 : -9dB                                                                           |          |
|                         |     |                       |         | (1dB steps)                                                                            |          |
|                         |     |                       |         | 11000 : 12dB                                                                           |          |
|                         |     |                       |         | 11001 to 11111 : Reserved                                                              |          |

Register 9Dh SE2\_5BEQ\_R4G

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R158 (9Eh)<br>SE2_5BEQ_<br>R0P | 15:0 | SE2_5BEQ_R0<br>P[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register 9Eh SE2\_5BEQ\_R0P

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R159 (9Fh)<br>SE2_5BEQ_<br>R0A | 15:0 | SE2_5BEQ_R0<br>A[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register 9Fh SE2\_5BEQ\_R0A



| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R160 (A0h)<br>SE2_5BEQ_<br>R0B | 15:0 | SE2_5BEQ_R0<br>B[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A0h SE2\_5BEQ\_R0B

| REGISTER   | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                              | REFER TO |
|------------|------|-------------|-----------|----------------------------------------------------------|----------|
| ADDRESS    |      |             |           |                                                          |          |
| R161 (A1h) | 15:0 | SE2_5BEQ_R1 | 0000_0001 | Filter coefficients for Signal Enhancement 2 (SE2) right |          |
| SE2_5BEQ_  |      | P[15:0]     | _1100_010 | channel 5-band EQ filter                                 |          |
| R1P        |      |             | 1         |                                                          |          |

Register A1h SE2\_5BEQ\_R1P

| REGISTER                       | BIT  | LABEL                  | DEFAULT   | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|-----------|-----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |           |                                                                                   |          |
| R162 (A2h)<br>SE2_5BEQ_<br>R1A | 15:0 | SE2_5BEQ_R1<br>A[15:0] | - · · · - | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A2h SE2\_5BEQ\_R1A

| REGISTER                       | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |         |                                                                                   |          |
| R163 (A3h)<br>SE2_5BEQ_<br>R1B | 15:0 | SE2_5BEQ_R1<br>B[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A3h SE2\_5BEQ\_R1B

| REGISTER                       | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |         |                                                                                   |          |
| R164 (A4h)<br>SE2_5BEQ_<br>R1C | 15:0 | SE2_5BEQ_R1<br>C[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A4h SE2\_5BEQ\_R1C

| REGISTER               | BIT  | LABEL                  | DEFAULT         | DESCRIPTION                                                                       | REFER TO |
|------------------------|------|------------------------|-----------------|-----------------------------------------------------------------------------------|----------|
| ADDRESS                |      |                        |                 |                                                                                   |          |
| R165 (A5h)<br>SE2_5BEQ | 15:0 | SE2_5BEQ_R2<br>P[15:0] | _ · · · · _ · · | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |
| R2P                    |      |                        |                 |                                                                                   |          |

Register A5h SE2\_5BEQ\_R2P

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT   | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|-----------|-----------------------------------------------------------------------------------|----------|
| R166 (A6h)<br>SE2_5BEQ_<br>R2A | 15:0 | SE2_5BEQ_R2<br>A[15:0] | - · · · - | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A6h SE2\_5BEQ\_R2A



| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                              | REFER TO |
|---------------------|------|-------------|-----------|----------------------------------------------------------|----------|
| R167 (A7h)          | 15:0 | SE2_5BEQ_R2 | 1111_0011 | Filter coefficients for Signal Enhancement 2 (SE2) right |          |
| SE2_5BEQ_           |      | B[15:0]     | _0111_001 | channel 5-band EQ filter                                 |          |
| R2B                 |      |             | 1         |                                                          |          |

 $\textbf{Register A7h}~\texttt{SE2\_5BEQ\_R2B}$ 

| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT   | DESCRIPTION                                              | REFER TO |
|---------------------|------|-------------|-----------|----------------------------------------------------------|----------|
| R168 (A8h)          | 15:0 | SE2_5BEQ_R2 | 0000_1010 | Filter coefficients for Signal Enhancement 2 (SE2) right |          |
| SE2_5BEQ_           |      | C[15:0]     | _0101_010 | channel 5-band EQ filter                                 |          |
| R2C                 |      |             | 0         |                                                          |          |

Register A8h SE2\_5BEQ\_R2C

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R169 (A9h)<br>SE2_5BEQ_<br>R3P | 15:0 | SE2_5BEQ_R3<br>P[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register A9h SE2\_5BEQ\_R3P

| REGISTER                       | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| ADDRESS                        |      |                        |         |                                                                                   |          |
| R170 (Aah)<br>SE2_5BEQ_<br>R3A | 15:0 | SE2_5BEQ_R3<br>A[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register Aah SE2\_5BEQ\_R3A

| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|-------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R171 (Abh)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_R3<br>B[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |
| R3B                     |      |                        | 1       |                                                                                   |          |

Register Abh SE2\_5BEQ\_R3B

| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT   | DESCRIPTION                                                                       | REFER TO |
|-------------------------|------|------------------------|-----------|-----------------------------------------------------------------------------------|----------|
| R172 (Ach)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_R3<br>C[15:0] | _         | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |
| SE2_5BEQ_<br>R3C        |      | C[15:0]                | _1010_110 | channel 5-band EQ filter                                                          |          |

Register Ach SE2\_5BEQ\_R3C

| REGISTER<br>ADDRESS    | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R173 (Adh)<br>SE2 5BEQ | 15:0 | SE2_5BEQ_R4<br>P[15:0] | _       | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |
| R4P                    |      |                        | 0       |                                                                                   |          |

Register Adh SE2\_5BEQ\_R4P



| REGISTER<br>ADDRESS     | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|-------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R174 (Aeh)<br>SE2_5BEQ_ | 15:0 | SE2_5BEQ_R4<br>A[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |
| R4A                     |      |                        | 0       |                                                                                   |          |

Register Aeh SE2\_5BEQ\_R4A

| REGISTER<br>ADDRESS            | BIT  | LABEL                  | DEFAULT | DESCRIPTION                                                                       | REFER TO |
|--------------------------------|------|------------------------|---------|-----------------------------------------------------------------------------------|----------|
| R175 (Afh)<br>SE2_5BEQ_<br>R4B | 15:0 | SE2_5BEQ_R4<br>B[15:0] |         | Filter coefficients for Signal Enhancement 2 (SE2) right channel 5-band EQ filter |          |

Register Afh SE2\_5BEQ\_R4B

WM8946

# **DIGITAL FILTER CHARACTERISTICS**

| PARAMETER                 | TEST CONDITIONS | MIN      | TYP    | MAX      | UNIT |
|---------------------------|-----------------|----------|--------|----------|------|
| ADC Filter                |                 | •        |        |          |      |
| Passband                  | +/- 0.1dB       | 0        |        | 0.454 fs |      |
|                           | -6dB            |          | 0.5fs  |          |      |
| Passband Ripple           |                 |          |        | +/- 0.1  | dB   |
| Stopband                  |                 | 0.546s   |        |          |      |
| Stopband Attenuation      | f > 0.546 fs    | -60      |        |          | dB   |
| DAC Normal Filter         |                 |          |        |          |      |
| Passband                  | +/- 0.03dB      | 0        |        | 0.454 fs |      |
|                           | -6dB            |          | 0.5 fs |          |      |
| Passband Ripple           | 0.454 fs        |          |        | +/- 0.03 | dB   |
| Stopband                  |                 | 0.546 fs |        |          |      |
| Stopband Attenuation      | F > 0.546 fs    | -50      |        |          | dB   |
| DAC Sloping Stopband Filt | er              |          |        |          |      |
| Passband                  | +/- 0.03dB      | 0        |        | 0.25 fs  |      |
|                           | +/- 1dB         | 0.25 fs  |        | 0.454 fs |      |
|                           | -6dB            |          | 0.5 fs |          |      |
| Passband Ripple           | 0.25 fs         |          |        | +/- 0.03 | dB   |
| Stopband 1                |                 | 0.546 fs |        | 0.7 fs   |      |
| Stopband 1 Attenuation    | f > 0.546 fs    | -60      |        |          | dB   |
| Stopband 2                |                 | 0.7 fs   |        | 1.4 fs   |      |
| Stopband 2 Attenuation    | f > 0.7 fs      | -85      |        |          | dB   |
| Stopband 3                |                 | 1.4 fs   |        |          |      |
| Stopband 3 Attenuation    | F > 1.4 fs      | -55      |        |          | dB   |

| DAC FILTER       | lS .        | ADC FILTERS |             |  |
|------------------|-------------|-------------|-------------|--|
| Mode             | Group Delay | Mode        | Group Delay |  |
| Normal           | 16.5 / fs   | Normal      | 16.5 / fs   |  |
| Sloping Stopband | 18 / fs     |             |             |  |

## **TERMINOLOGY**

- 1. Stop Band Attenuation (dB) the degree to which the frequency spectrum is attenuated (outside audio band)
- 2. Pass-band Ripple any variation of the frequency response in the pass-band region

### Notes:

1. The Group Delays are quoted with the DSP SE1, SE2, and SE3 filters disabled. Enabling the DSP SE1, SE2, and SE3 filters will increase the Group Delay

## **ADC FILTER RESPONSE**



Figure 47 ADC Frequency Response up to 4 x fs (Sample rate, fs = 48kHz)



Figure 48 ADC Pass Band Frequency Response up to fs/2 (Sample rate, fs = 48kHz)

## **ADC HIGHPASS FILTER RESPONSE**



Figure 49 ADC High Pass Filter Frequency Response for the Hi-Fi Mode (Sample rate, fs = 48kHz)



Figure 50 ADC High Pass Filter Frequency Response for the Application Mode (Sample rate, fs = 48kHz)

## **DAC FILTER RESPONSE**



Figure 51 DAC Frequency Response up to 4 x fs (Sample rate, fs = 32k to 48kHz)



Figure 52 DAC Frequency Response up to 4 x fs (Sample rate, fs = 16k to 24kHz)



Figure 53 DAC Frequency Response up to 4 x fs (Sample rate, fs = 8k to 12kHz)



Figure 54 DAC Pass Band Frequency Response up to fs/2 (Sample rate, fs = 8k to 12kHz, 16k to 24kHz, 32k to 48kHz)

## APPLICATIONS INFORMATION

### RECOMMENDED EXTERNAL COMPONENTS

#### **AUDIO INPUT PATHS**

The WM8946 provides up to 6 analogue audio inputs (including the auxiliary inputs AUX1 and AUX2). Each of these inputs is referenced to the internal DC reference, VMID. A DC blocking capacitor is required for each input pin used in the target application. The choice of capacitor is determined by the filter that is formed between that capacitor and the input impedance of the input pin. The circuit is illustrated in Figure 55. (Note that capacitors are not required on any unused audio input.)



$$F_C = \frac{1}{2\pi RC}$$

Fc = high pass 3dB cut-off frequency

Figure 55 Audio Input Path DC Blocking Capacitor

When the input impedance is known, and the cut-off frequency is known, then the minimum capacitor value may be derived easily. For practical use, a  $1\mu F$  capacitance for all audio inputs can be recommended for most cases. Tantalum electrolytic capacitors are particularly suitable as they offer high stability in a small package size.

Ceramic equivalents are a cost effective alternative to the superior tantalum packages, but care must be taken to ensure the desired capacitance is maintained at the LDOVOUT operating voltage. Also, ceramic capacitors may show microphonic effects, where vibrations and mechanical conditions give rise to electrical signals. This is particularly problematic for microphone input paths where a large signal gain is required.

A single capacitor is required for a line input or single-ended microphone connection. In the case of a differential microphone connection, a DC blocking capacitor is required on both input pins.

#### **HEADPHONE / LINE OUTPUT PATHS**

The WM8946 provides four outputs (LINEOUTL, LINEOUTR, SPKOUTL and SPKOUTR). Each of these outputs is referenced to the internal DC reference, VMID. In any case where a line output is used in a single-ended configuration (i.e. referenced to GND), a DC blocking capacitor is required in order to remove the DC bias. In the case where a pair of line outputs is configured as a BTL differential pair, then the DC blocking capacitor should be omitted.

The choice of capacitor is determined from the filter that is formed between the capacitor and the load impedance. A  $1\mu F$  capacitance would be a suitable choice for a line load. For a headphone load a larger value (100 $\mu F$  for a 32 ohm load or 220 $\mu F$  for a 16 ohm load) would be required. Tantalum electrolytic capacitors are again particularly suitable but ceramic equivalents are a cost effective alternative. Care must be taken to ensure the desired capacitance is maintained at the appropriate operating voltage.





Figure 56 DC-blocking Components for Line Output



Figure 57 DC-blocking Components for Headphone Output

## **BTL SPEAKER OUTPUT CONNECTION**

The BTL speaker output connection is a differential mode of operation. The loudspeaker may be connected directly across the SPKOUTL and SPKOUTR pins. No additional external components are required in this case.

#### **POWER SUPPLY DECOUPLING**

Electrical coupling exists particularly in digital logic systems where switching in one sub-system causes fluctuations on the power supply. This effect occurs because the inductance of the power supply acts in opposition to the changes in current flow that are caused by the logic switching. The resultant variations (or 'spikes') in the power supply voltage can cause malfunctions and unintentional behavior in other components. A decoupling (or 'bypass') capacitor can be used as an energy storage component which will provide power to the decoupled circuit for the duration of these power supply variations, protecting it from malfunctions that could otherwise arise.

Coupling also occurs in a lower frequency form when ripple is present on the power supply rail caused by changes in the load current or by limitations of the power supply regulation method. In audio components such as the WM8946, these variations can alter the performance of the signal path, leading to degradation in signal quality. A decoupling (or 'bypass') capacitor can be used to filter these effects, by presenting the ripple voltage with a low impedance path that does not affect the circuit to be decoupled.

These coupling effects are addressed by placing a capacitor between the supply rail and the corresponding ground reference. In the case of systems comprising multiple power supply rails, decoupling should be provided on each rail.

The recommended power supply decoupling capacitors for WM8946 are listed below in Table 71.

| POWER SUPPLY                 | DECOUPLING CAPACITOR |
|------------------------------|----------------------|
| DCVDD, DBVDD, LDOVDD, SPKVDD | 4.7μF ceramic        |
| LDOVOUT                      | 2.2μF ceramic        |
| VMIDC                        | 4.7μF ceramic        |

**Table 71 Power Supply Decoupling Capacitors** 

All decoupling capacitors should be placed as close as possible to the WM8946 device. The connection between GND, the LDOVOUT decoupling capacitor and the main system ground should be made at a single point as close as possible to the GND ball of the WM8946.

The VMIDC capacitor is not, technically, a decoupling capacitor. However, it does serve a similar purpose in filtering noise on the VMID reference. The connection between GND, the VMID decoupling capacitor and the main system ground should be made at a single point as close as possible to the GND ball of the WM8946.

Due to the wide tolerance of many types of ceramic capacitors, care must be taken to ensure that the selected components provide the required capacitance across the required temperature and voltage ranges in the intended application. For most application the use of ceramic capacitors with capacitor dielectric X5R is recommended.

#### **MICROPHONE BIAS CIRCUIT**

The WM8946 is designed to interface easily with electret microphones. These may be connected in single-ended or differential configurations. The single-ended method allows greater capability for the connection of multiple audio sources simultaneously, whilst the differential method provides better performance due to its rejection of common-mode noise.

In either configuration, the microphone requires a bias current (electret condenser microphones) or voltage supply (silicon microphones), which can be provided by MICBIAS. This reference is generated by an output-compensated amplifier, which requires an external capacitor in order to guarantee accuracy and stability. The recommended capacitance is  $4.7\mu F$ , although it may be possible to reduce this to  $1\mu F$  if the analogue supply (LDOVOUT) is not too noisy. A ceramic type is a suitable choice here, providing that care is taken to choose a component that exhibits this capacitance at the intended MICBIAS voltage.

Note that the MICBIAS voltage may be adjusted using register control to suit the requirements of the microphone. Also note the WM8946 supports a maximum current of 3mA. If more than one microphone is connected to the MICBIAS, then combined current must not exceed 3mA.

A current-limiting resistor is also required when using an electret condenser microphone (ECM). The resistance should be chosen according to the minimum operating impedance of the microphone and MICBIAS voltage so that the maximum bias current of the WM8946 is not exceeded. Wolfson recommends a  $2.2 \mathrm{k}\Omega$  current limiting resistor as it provides compatibility with a wide range of microphone models.

The recommended connections for single-ended and differential microphone modes are illustrated in Figure 58 and Figure 59.





Figure 58 Single-Ended Microphone Connection



Figure 59 Pseudo-Differential Microphone Connection

## **VIDEO BUFFER COMPONENTS**

External components are required for the Video Buffer.

In a typical application, R<sub>LOAD</sub> = 75 $\Omega$ , R<sub>SOURCE</sub> = 75 $\Omega$ , R<sub>REF</sub> = 187 $\Omega$ .

See "Video Buffer" for details of alternative components under different load impedance conditions.



Figure 60 Typical Components for Video Buffer

### RECOMMENDED EXTERNAL COMPONENTS DIAGRAM

Figure 61 provides a summary of recommended external components for WM8946. Note that the actual requirements may differ according to the specific target application.



Figure 61 WM8946 Recommended External Components Diagram

# **PCB LAYOUT CONSIDERATIONS**

Poor PCB layout will degrade the performance and be a contributory factor in EMI, ground bounce and resistive voltage losses. All external components should be placed as close to the WM8946 device as possible, with current loop areas kept as small as possible.



# **PACKAGE DIMENSIONS**



| Symbols | Dimensions (mm) |           |       |      |  |
|---------|-----------------|-----------|-------|------|--|
|         | MIN             | NOM       | MAX   | NOTE |  |
| Α       | 0.660           | 0.700     | 0.740 |      |  |
| A1      | 0.207           | 0.244     | 0.281 |      |  |
| A2      | 0.418           | 0.434     | 0.450 |      |  |
| D       | 2.945           | 2.970     | 2.995 |      |  |
| D1      |                 | 2.500 BSC |       |      |  |
| E       | 3.045           | 3.070     | 3.095 |      |  |
| E1      |                 | 2.500 BSC |       |      |  |
| е       |                 | 0.500 BSC |       | 5    |  |
| f1      | 0.223           |           |       |      |  |
| f2      | 0.273           |           |       |      |  |
| g       |                 | 0.022     |       |      |  |
| h       | 0.264           | 0.314     | 0.364 |      |  |
| aaa     | 0.025           |           |       |      |  |
| bbb     | 0.060           |           |       |      |  |
| ccc     |                 | 0.030     |       |      |  |
| ddd     |                 | 0.015     |       |      |  |

- NOTES:

  1. PRIMARY DATUM -Z- AND SEATING PLANE ARE DEFINED BY THE SPHERICAL CROWNS OF THE SOLDER BALLS.

  2. THIS DIMENSION INCLUDES STAND-OFF HEIGHT 'A1' AND BACKSIDE COATING.

  3. A1 CORNER IS IDENTIFIED BY INKLASER MARK ON TOP PACKAGE.

  4. BILATERAL TOLERANCE ZONE IS APPLIED TO EACH SIDE OF THE PACKAGE BODY.

  5. '0' REPRESENTS THE BASIC SOLDER BALL GRID PITCH.

  6. THIS DRAWING IS SUBJECT TO CHANGE WITHOUT NOTICE.

  7. FOLLOWS JEDEC DESIGN GUIDE MO-211-C.



## IMPORTANT NOTICE

Wolfson Microelectronics plc ("Wolfson") products and services are sold subject to Wolfson's terms and conditions of sale, delivery and payment supplied at the time of order acknowledgement.

Wolfson warrants performance of its products to the specifications in effect at the date of shipment. Wolfson reserves the right to make changes to its products and specifications or to discontinue any product or service without notice. Customers should therefore obtain the latest version of relevant information from Wolfson to verify that the information is current.

Testing and other quality control techniques are utilised to the extent Wolfson deems necessary to support its warranty. Specific testing of all parameters of each device is not necessarily performed unless required by law or regulation.

In order to minimise risks associated with customer applications, the customer must use adequate design and operating safeguards to minimise inherent or procedural hazards. Wolfson is not liable for applications assistance or customer product design. The customer is solely responsible for its selection and use of Wolfson products. Wolfson is not liable for such selection or use nor for use of any circuitry other than circuitry entirely embodied in a Wolfson product.

Wolfson's products are not intended for use in life support systems, appliances, nuclear systems or systems where malfunction can reasonably be expected to result in personal injury, death or severe property or environmental damage. Any use of products by the customer for such purposes is at the customer's own risk.

Wolfson does not grant any licence (express or implied) under any patent right, copyright, mask work right or other intellectual property right of Wolfson covering or relating to any combination, machine, or process in which its products or services might be or are used. Any provision or publication of any third party's products or services does not constitute Wolfson's approval, licence, warranty or endorsement thereof. Any third party trade marks contained in this document belong to the respective third party owner.

Reproduction of information from Wolfson datasheets is permissible only if reproduction is without alteration and is accompanied by all associated copyright, proprietary and other notices (including this notice) and conditions. Wolfson is not liable for any unauthorised alteration of such information or for any reliance placed thereon.

Any representations made, warranties given, and/or liabilities accepted by any person which differ from those contained in this datasheet or in Wolfson's standard terms and conditions of sale, delivery and payment are made, given and/or accepted at that person's own risk. Wolfson is not liable for any such representations, warranties or liabilities or for any reliance placed thereon by any person.

#### ADDRESS:

Wolfson Microelectronics plc 26 Westfield Road Edinburgh EH11 2QB United Kingdom

Tel :: +44 (0)131 272 7000 Fax :: +44 (0)131 272 7001

Email :: sales@wolfsonmicro.com



# **REVISION HISTORY**

| DATE     | REV | DESCRIPTION OF CHANGES                                                          | PAGE       | CHANGED BY |
|----------|-----|---------------------------------------------------------------------------------|------------|------------|
| 11/10/10 | 4.0 | Product Status updated to Production Data                                       |            |            |
|          |     | Added comment about ADC volume being in digital filter block                    | 30         |            |
|          |     | Added comment about DAC volume being in digital filter block                    | 47         |            |
|          |     | Notch filter plots updated                                                      | 36         |            |
|          |     | Added note about DAC_VOL_RAMP rate                                              | 48         |            |
| 15/05/11 | 4.1 | Added note about LDOVDD being enabled before SPKVDD to ensure pop-free start-up | 8          | JJ         |
| 25/06/12 | 4.2 | Package Diagram updated to DM063B                                               |            | JMacD      |
| 26/06/12 | 4.2 | Added note that SYSCLK is required for Volume Update functions.                 | 25, 47, 59 | PH         |
|          |     | Noted the notch filter is not usable below 120Hz                                | 35         |            |
| 04/07/12 | 4.2 | Reel quantity changed to 5,000                                                  | 6          | JMacD/TS   |
| 27/07/12 | 4.3 | Package Diagram dimensions updated in Features                                  |            | JMacD      |

